/*
    Theme Name: Custom Theme
    Description: Custom Theme
    Version: 1.4.2
    Author: Karina
*/

/*-- n49 search bar */
.searchapp-iframe-background-match {
    -webkit-text-size-adjust: 100%;
    color: #666;
    font-size: 12px;
    font-family: 'Roboto', sans-serif;
    outline: none;
    background-color: #ededed;
    height: 1000px;
    left: 0;
    right: 0;
    position: absolute;
}

.searchapp-iframe-wrapper {
    -webkit-text-size-adjust: 100%;
    color: #666;
    font-size: 12px;
    font-family: 'Roboto', sans-serif;
    outline: none;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100000;
    height: 64px;
}

/*------------------------------------*\
    MAIN
\*------------------------------------*/

@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');

/* global box-sizing */
*,
*:after,
*:before {
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
/* html element 62.5% font-size for REM use */
html {
    font-size: 62.5%;
}
body {
    font: 400 16px/1.5 "Roboto", sans-serif;
    color: #3b3b3b;
    margin: 0;
}

.wpcf7-spinner,
.acf-map .gmnoprint,
.acf-map .gm-style-cc,
.social-wrap.share .addtoany_list a span,
.btn-menu,
.header .toggle,
.pagination a,
.pagination span,
.meta-wrap.single h1::after,
.desktop-hidden,
.hidden,
.jBox-closeButton svg {
    display: none;
}

.has-featured > .flex:first-child .mb-15 {
	display: block;
}

.header .menu-item-has-children > a > .toggle,
.manual-pagination .pagination a.next {
    display: inline-block;
}

/* clear */
.clear:before,
.clear:after {
    content: ' ';
    display: table;
}

.clear:after {
    clear: both;
}
.clear {
    *zoom: 1;
}
img {
    max-width: 100%;
    vertical-align: bottom;
    height: auto;
}
a {
    color: #3b3b3b;
    text-decoration: none;
    transition: all 0.3s ease 0s;
}
a:hover,
.widget-info a:hover,
.text-white .meta-wrap .author a:hover {
    color: #ec2028;
}
a:focus {
    outline: 0;
}
a:hover,
a:active {
    outline: 0;
}

input:focus {
    outline: 0;
    border: 1px solid #04A4CC;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    line-height: 1.2;
    margin: 0 0 20px;
}

h1 {
    font-size: 38px;
}

h2 {
    font-size: 28px;
}

h3 {
    font-size: 20px;
}

p {
    margin: 0 0 30px;
}

h1:last-child,
h2:last-child,
h3:last-child,
h4:last-child,
h5:last-child,
h6:last-child,
p:last-child {
    margin: 0;
}

article ul {
    padding: 0 0 0 15px;
    margin: 0 0 40px;
}

article ul li {
    margin: 0 0 25px;
}

article p a {
    text-decoration: underline;
}

.link,
article .link {
    font-size: 16px;
    font-weight: 500;
    color: #ec2028;
    text-decoration: none;
}

.link svg {
    margin-left: 5px;
}

.overflow {
    overflow: hidden;
}

.left {
    float: left;
}

.right {
    float: right;
}

.text-right {
    text-align: right;
}

.text-left {
    text-align: left;
}

.text-center {
    text-align: center;
}

.font-weight-500 {
    font-weight: 500;
}

.font-size-48 {
    font-size: 48px;
}

.font-size-28 {
    font-size: 28px;
}

.font-size-20 {
    font-size: 20px;
}

.font-size-18 {
    font-size: 18px;
}

.font-size-14 {
    font-size: 14px;
}

.font-size-12 {
    font-size: 12px;
}

.line-height-40 {
	line-height: 40px;
}

.anchor {
    position: relative;
    top: -200px;
}

.subtitle {
    font-size: 14px;
    color: #ec2028;
    margin: 0;
}

.btn-wrap {
    font-size: 0;
}

.btn-wrap .btn,
.btn-wrap a.img {
	display: inline-block;
    margin: 0 10px 10px 0;
}

.btn-wrap a.img img {
	max-width: 40px;
}

.btn-wrap.as-links a {
	font-size: 14px;
	font-weight: 700;
	line-height: 24px;
	margin: 0 15px 10px 0;
}

.btn-wrap.as-links a::last-child {
	margin-right: 0;
}

.btn-wrap.as-links a svg {
	display: inline-block;
	vertical-align: top;
	margin: 0 3px 0 0;
}

.btn-lines {
    text-align: center;
    position: relative;
    overflow: hidden;
}

.btn-lines::before,
.btn-lines::after {
    content: '';
    display: block;
    width: 170px;
    height: 1px;
    background: #ec2028;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.btn-lines::before {
    margin-left: -200px;
}

.btn-lines::after {
    margin-left: 200px;
}

.text-right > .btn-wrap .btn {
    margin: 0 0 10px 10px;
}

.btn-wrap .btn:last-child {
    margin-right: 0;
}

.text-right > .btn-wrap .btn:first-child,
.btn-wrap .btn:last-child {
    margin-left: 0;
}

.btn,
.manual-pagination .pagination a.next {
    display: inline-block;
    vertical-align: top;
    position: relative;
    cursor: pointer;
    font-family: "Roboto", sans-serif;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.2;
    color: #3b3b3b;
    text-align: center;
    border: 1px solid #3b3b3b;
    border-radius: 0;
    outline: 0;
    background: #fff;
    padding: 9px 20px;
    transition: all 0.3s ease 0s;
    text-decoration: none;
}

.btn:hover,
.manual-pagination .pagination a.next:hover {
    color: #fff;
    border: 1px solid #3b3b3b;
    background: #3b3b3b;
    opacity: 0.8;
    text-decoration: none;
}

.btn.small {
    padding: 5px 18px 7px;
}

.btn.large {
    padding: 11px 25px;
}

.btn.red {
    background-color: #e20000;
    border-color: #e20000;
    color: #fff;
}

.btn.black {
    background-color: #3b3b3b;
    border-color: #3b3b3b;
    color: #fff;
}

.social-wrap {
    font-size: 0;
}

.social-wrap a {
    display: inline-block;
    vertical-align: top;
    margin: 0 28px 0 0;
}

.social-wrap a:last-child {
    margin-right: 0;
}

.social-wrap a svg {
    width: 32px;
    height: 32px;
    border-radius: 50%;
}

.social-wrap a svg path,
.social-wrap a svg circle,
.social-wrap a svg polygon {
    transition: all 0.3s ease 0s;
}

.social-wrap a svg .icon {
    fill: #515151;
}

.social-wrap a svg .dot {
    fill: #fff;
}

.social-wrap a svg .circle,
.social-wrap a:hover svg .icon {
    fill: #fff;
}

.social-wrap a:hover svg .circle,
.social-wrap a:hover svg .dot {
    fill: #ec2028;
}

.social-wrap.white a {
	margin: 0 12px 0 0;
}

.social-wrap.white svg .icon,
.social-wrap.white a:hover svg .icon{
	fill: #3b3b3b;
}

.social-wrap.white svg .circle {
	fill: transparent;
	stroke: #e9e9ee;
	stroke-miterlimit: 10;
}

.social-wrap.white a:hover svg .circle {
	fill: #e9e9ee;
}

.social-wrap.share {
    margin: 25px 0 40px;
}

.social-wrap.share.last {
    margin-bottom: 0;
}

.social-wrap.share.first {
	margin-top: 0;
}

.social-wrap.share a {
    padding: 0;
    margin-right: 12px;
	border-radius: 50%;
	width: 31px;
	height: 31px;
	transition: all 0.3s ease 0s;
}

.social-wrap.share a:hover {
	background: #e9e9ee;
}

.social-wrap.share a:hover img {
	opacity: 1;
}


.social-wrap.normal a {
    vertical-align: middle;
    margin: 0 12px 0 0;
}

.social-wrap.normal a svg {
    width: auto;
    height: auto;
    border-radius: 0;
}

.social-wrap.normal a svg path {
    transition: all 0.3s ease 0s;
}

.social-wrap.normal a:hover svg path {
    fill: #e20000;
}

.social-wrap.normal span {
    display: inline-block;
    vertical-align: middle;
    font-size: 16px;
    font-weight: 500;
    margin-right: 15px;
}

.scrollup {
    display: none;
    position: fixed;
    bottom: 30px;
    right: 30px;
    z-index: 99999;
    cursor: pointer;
}

.sticky-sidebar {
    will-change: min-height;
}

.sticky-sidebar-inner {
    position: relative;
    transform: translate(0, 0);
    transform: translate3d(0, 0, 0);
    will-change: position, transform;
}

.img-wrap {
    display: block;
    position: relative;
    background: #000;
    border-radius: 10px;
    overflow: hidden;
}

.img-wrap img {
    width: 100%;
    border-radius: 10px;
    transition: all 1s ease 0s;
}

a.img-wrap:hover img {
    transform: scale(1.1);
}

.img-wrap.normal,
.img-wrap.normal img {
    width: auto;
    background: none;
    border-radius: 0;
}

.img-wrap.round,
.img-wrap.round img {
    border-radius: 50%;
    background: none;
}

.img-wrapper {
    font-size: 0;
}

.img-wrapper > img,
.img-wrapper a > img {
    vertical-align: middle;
    transition: all 0.3s ease 0s;
    margin-right: 35px;
}

.img-wrapper a:hover > img {
    opacity: 0.75;
}

.img-wrapper > img:last-child,
.img-wrapper.small > img:last-child,
.img-wrapper a:last-child > img,
.img-wrapper.small a:last-child > img {
    margin-right: 0;
}

.img-wrapper.small {
    margin-left: 35px;
}

.img-wrapper.small > img,
.img-wrapper.small a > img {
    margin-right: 28px;
}

.img-wrapper.srcset img {
    max-width: 120px;
}

.img-wrap-medium.normal {
	background: none no-repeat scroll center center transparent;
	background-size: cover;
	width: 100%;
	height: 150px;
	position: relative;
}

.img-wrap-medium.normal::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: 0;
	transition: all 0.3s ease 0s;
}

.img-wrap-medium.normal:hover::before {
	opacity: 0.2;
}

.img-wrap-medium img {
	object-fit: cover;
}

.has-featured > .flex:first-child .img-wrap-medium.normal {
	height: 370px;
}

/*------------------------------------*\
    ICONS
\*------------------------------------*/


/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/

.wrapper {
    max-width: 1180px;
    width: 100%;
    padding: 0 20px;
    margin: 0 auto;
    position: relative;
}

.wrapper.fullwidth {
    max-width: 100%;
    padding: 0;
}

.header {
    width: 100%;
    position: relative;
    z-index: 999;
    background: #fff;
    border-bottom: 1px solid #e7e7e7;
}

.header.stuck {
    position: fixed;
    top: 0;
    left: 0;
    animation: fadeInDown ease-in-out 0.6s both;
}

.header .logo {
    font-size: 0;
}

.header .logo a,
.header .logo span {
    display: inline-block;
    vertical-align: baseline;
}

.header .logo svg,
.header .logo img,
.header .logo a {
    width: 100%;
    max-width: 81px;
}

.header .logo span {
    font-size: 12px;
    font-weight: 500;
    color: #3b3b3b;
}

.header .nav {
    height: 60px;
}

.nav ul {
    font-size: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.nav li {
    display: inline-block;
    vertical-align: top;
    position: relative;
    margin: 0 20px;
}

.nav > ul,
.nav > ul > li,
.nav > ul > li > a {
    height: 100%;
}

.nav li.sep-right {
    margin-right: 5px;
}

.nav li.sep-right::after {
    content: '';
    display: inline-block;
    vertical-align: top;
    width: 1px;
    height: 32px;
    background: #e7e7e7;
    margin-left: 20px;
    position: relative;
    top: 50%;
    transform: translate(0, -50%);
}

.nav > ul > li > a {
    line-height: 60px;
}

.nav a {
    display: inline-block;
    vertical-align: top;
    font-size: 15px;
    font-weight: 500;
    color: #3b3b3b;
    position: relative;
}

.nav a:hover {
    color: #ec2028;
}

.nav > ul > li > a > svg {
    width: 12px;
    height: 7px;
    margin: 0 0 0 7px;
    transition: all 0.3s ease 0s;
}

.nav > ul > li > a:hover > svg {
    fill: #ec2028;
}

.nav > ul > li > a::after {
    content: '';
    width: 100%;
    height: 1px;
    background: none;
    position: absolute;
    left: 0;
    bottom: 0;
    transition: all 0.3s ease 0s;
}

.nav > ul > li > a:hover::after {
    background: #ec2028;
}

.nav .sub-menu {
    display: none;
    position: absolute;
    right: 0;
    top: 100%;
    width: 230px;
    box-shadow: 0px 2px 10px 0px rgba(0,0,0,0.1);
}

.nav li:hover .sub-menu {
    display: block;
}

.nav .sub-menu li {
    display: block;
    margin: 0;
    border-bottom: 1px solid #e8e8e8;
}

.nav .sub-menu li:last-child {
    border: 0;
}

.nav .sub-menu a {
    display: block;
    font-size: 14px;
    background: #fff;
    padding: 9px 20px;
    position: relative;
}

.nav .sub-menu a:hover {
    color: #3b3b3b;
    text-decoration: none;
    background: #e8e8e8;
}

.header-wrap,
.header-wrap.section {
    position: relative;
    height: auto;
    background: #f2f3f2;
}

.header-wrap.size-400 {
    height: 400px;
}

.header-wrap.size-500 {
    height: 500px;
}

.header-wrap.size-550 {
    height: 550px;
}

.header-wrap.size-700 {
    height: 700px;
}

.header-wrap.fullscreen {
    height: 100vh;
    height: calc(100vh - 130px);
}

.header-wrap .bgr {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: none no-repeat scroll center center transparent;
    background-size: cover;
}

.header-wrap.slider .caption {
    font-size: 20px;
    height: 100%;
    align-items: flex-end;
    justify-content: normal;
    text-align: left;
    padding: 50px 0;
}

.header-wrap.slider {
    object-fit: cover;
}

.header-wrap.bgr-black {
    background: #000;
}

.sidebar {
    background: #fff;
}

.widget {
    margin: 0 0 30px;
}

.widget:last-child {
    margin: 0;
}

.widget-info,
.widget-info:last-child {
    background: #fafafa;
    border-bottom: 2px solid #ec2028;
    padding: 30px 30px 25px;
    margin: 0 0 30px;
}

.widget-info a {
    display: block;
    font-size: 14px;
    color: #000000;
    border-bottom: 1px solid #e7e7e7;
    padding: 10px 0;
}

.widget-info a:last-child {
    border-bottom: 0;
}

.widget-map {
    border-bottom: 2px solid #ec2028;
    position: relative;
}

.widget-map img {
    width: 100%;
}

.widget-map .btn {
    width: 100%;
    max-width: 200px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.footer .logo {
    font-size: 0;
}

.footer .logo svg,
.footer .logo img {
    width: 100%;
    max-width: 81px;
    height: 30px;
}

.footer .logo a,
.footer .logo span {
    display: inline-block;
    vertical-align: baseline;
}

.footer .logo span {
    font-size: 12px;
    font-weight: 500;
    color: #3b3b3b;
}

.footer .logo span {
    color: #fff;
}

.footer {
    background: #515151;
    padding: 50px 0 0;
}

.footer a:not(.btn):hover {
    text-decoration: underline;
}

.footer .bottom {
    background: #494949;
    padding: 45px 0;
    margin: 30px 0 0;
}

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

.footer ul li {
    margin: 0 0 2px;
}

.footer ul a {
    font-size: 12px;
}

.footer .menu-inline ul li {
    display: inline-block;
    vertical-align: top;
    margin-right: 30px;
}

.footer .menu-inline ul li:last-child {
    margin-right: 0;
}

.footer .menu-inline ul li a {
    font-size: 14px;
}

.breadcrumbs {
	font-size: 12px;
	margin: 15px 0 0;
}

.breadcrumbs .sep {
	margin: 0 2px;
}

/*------------------------------------*\
    SLIDER
\*------------------------------------*/

.slick-slider {
    font-size: 0;
    position: relative;
    display: block;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0;
}

.slick-list:focus {
    outline: none;
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
}

.slick-track:before,
.slick-track:after {
    display: table;
    content: '';
}

.slick-track:after {
    clear: both;
}
.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    display: none;
    height: 100%;
    min-height: 1px;
    text-align: left;
    height: auto;
    padding: 0;
    margin: 0 20px 0 0;
    background: none;
    position: relative;
    outline: 0;
}

.slick-slide img {
    display: inline-block;
    width: auto;
    max-width: 100%;
    vertical-align: bottom;
    height: auto;
}

.slick-slide.slick-loading img {
    display: none;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: inline-block;
    text-align: center;
    vertical-align: top;
}

.slick-loading .slick-slide {
    visibility: hidden;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
}

.slick-arrow {
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    padding: 0;
    cursor: pointer;
    color: transparent;
    opacity: 1;
    border: none;
    outline: none;
    z-index: 9;
    text-align: center;
    border-radius: 0;
    width: 31px;
    height: 31px;
    background: none;
    transform: translate(0, -50%);
    transition: all 0.3s ease 0s;
    box-shadow: 0 0 10px 0px rgba(0,0,0,0.2);
    border-radius: 50%;
}

.slick-arrow path {
    transition: all 0.3s ease 0s;
}

.slick-arrow .arrow {
    stroke: #fff;
}

.slick-arrow:hover .arrow {
    stroke: #494949;
}

.slick-arrow .circle {
    fill: none;
    stroke: #fff;
}

.slick-arrow:hover .circle {
    fill: #fff;
    stroke: #fff;
}

.slick-arrow:hover,
.arrows-hidden:hover .slick-arrow {
    opacity: 1;
}

.arrows-hidden .slick-arrow {
    opacity: 0;
}

.arrows-inside .slick-prev {
    left: 0;
}

.arrows-inside .slick-next {
    right: 0;
}

.slick-next {
    right: -60px;
}

.slick-prev {
    left: -60px;
}

.carousel-normal .slick-list,
.carousel-normal .slick-track,
.carousel-normal .slick-slide,
.carousel-normal .slick-slide > div,
.carousel-normal .slide,
.carousel-normal .slide .bgr {
    height: 100%;
}

.carousel {
    margin: 40px 0;
}

.carousel .slick-slide {
    text-align: left;
    margin: 0;
}

.carousel .slick-track {
	display: flex !important;
	align-items: center;
}

.carousel .slide > figure,
.carousel .slide > img,
.carousel .slide > iframe {
    display: block;
    max-width: 85%;
    margin: 0 auto;
}

.carousel .slide figure {
	height: 400px;
}

.carousel .slide figure > img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.carousel.arrows-inside iframe {
	margin-left: auto !important;
	margin-right: auto !important;
	position: relative !important;
}

/*------------------------------------*\
    PAGES
\*------------------------------------*/

.text-white,
.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6,
.text-white h7,
.text-white h8,
.text-white p,
.text-white a:not(.btn) {
    color: #fff;
}

.color-ec2028 {
    color: #ec2028;
}

.flex {
    display: -webkit-flex;
    display: flex;
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: space-between;
}

.flex.column {
    flex-direction: column;
}

.flex .grow {
    flex-grow: 1;
}

.flex.center {
    align-items: center;
}

.flex.justify-start {
    justify-content: start;
}

.flex.justify-end {
    justify-content: end;
}

.flex.top {
    align-items: flex-start;
}

.flex.bottom {
    align-items: flex-end;
}

.flex.as-sep {
    border-top: 1px solid #616161;
    padding-top: 25px;
    margin-top: 25px;
}

.section {
    padding: 60px 0;
    position: relative;
    background: none no-repeat scroll center center transparent;
    background-size: cover;
}

.section.fullscreen {
    height: 100vh;
	height: calc(100vh - 60px);
}

.section.fullscreen .wrapper,
.section.fullscreen .wrapper > .flex {
    height: 100%;
}

.acf-map {
    width: 100%;
    height: 100%;
}

.acf-map .info-box {
    width: 450px;
    margin: 0;
}

.acf-map .info-box img {
    width: 100%;
    max-width: 100%;
    object-fit: cover;
    height: 100%;
}

.acf-map .info-box .content {
    padding: 15px;
}

.acf-map .info-box .content > p {
    font-size: 14px;
    font-weight: 700;
    margin: 0 0 5px;
}

.acf-map .info-box .rating-wrap {
    margin: 0 0 10px;
}

.acf-map .info-box a {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: #ec2028;
    margin: 10px 0 0;
}

.gm-style-iw-d {
    background: #fff;
}

.gm-style .gm-style-iw-c {
    padding: 0;
    box-shadow: none;
    border-radius: 0;
    background: none;
}

.gm-style .gm-style-iw-c button {
    width: 30px !important;
    height: 30px !important;
    background: #fff !important;
    opacity: 1;
}

.gm-style .gm-style-iw-c button span {
    width: 20px !important;
    height: 20px !important;
    margin: 0 auto !important;
}

.tabs ul.horizontal {
    list-style: none;
    margin: 0 0 35px;
    padding: 0;
    border-bottom: 1px solid #e1e1e1;
}

.tabs ul.horizontal li {
    display: inline-block;
    vertical-align: top;
}

.tabs ul.horizontal li a {
    font-size: 12px;
    font-weight: 400;
    text-transform: uppercase;
    text-decoration: none;
    color: #929292;
    display: block;
    border-bottom: 2px solid transparent;
    padding: 5px 25px;
    margin-bottom: -1px;
}

.tabs ul.horizontal li a:hover,
.tabs ul.horizontal li.active a {
    color: #053d95;
    border-color: #00a8ff;
}

.accordion {
    border-bottom: 1px solid #dcdcdc;
}

.accordion .title {
    font-size: 24px;
    font-weight: 600;
    position: relative;
    cursor: pointer;
    margin: 0;
    padding: 35px 0 35px 195px;
    border-top: 1px solid #dcdcdc;
}

.accordion span {
    width: 30px;
    height: 30px;
    position: absolute;
    left: 0;
    top: 35px;
}

.accordion span svg {
    width: 100%;
    height: 100%;
}

.accordion .items {
    padding: 0 0 30px 195px;
}

.as-menu-list {
    column-count: 5;
}

.meta-wrap .category,
.meta-wrap .category a {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 1px;
    color: #ec2028;
}

.text-white .meta-wrap .category,
.text-white .meta-wrap .category a {
    color: #fff;
}

.meta-wrap .category {
    margin: 0 0 5px;
}

.meta-wrap h1,
.meta-wrap h2,
.meta-wrap h3 {
    margin: 0 0 15px;
}

.meta-wrap h1::after,
.meta-wrap h2::after,
.meta-wrap h1::after,
.meta-wrap h3::after {
    content: '';
    display: block;
    width: 80px;
    height: 1px;
    background: #ec2028;
    margin: 25px 0 0;
}

.meta-wrap h2::after {
    margin: 15px 0 0;
}

.meta-wrap h3::after {
    margin: 20px 0 0;
}

.meta-wrap .date,
.meta-wrap .author a,
.meta-wrap .author span {
    font-size: 14px;
    font-weight: 500;
    margin: 0 0 15px;
}

.meta-wrap .date span {
    display: inline-block;
    color: #fff;
    background: #ec2028;
    border-radius: 12px;
    padding: 3px 15px;
    text-align: center;
    margin: 0 0 0 10px;
}

.meta-wrap .author {
    font-size: 0;
}

.meta-wrap .author .avatar a {
    display: inline-block;
    margin: 0 0 0 -10px;
}

.meta-wrap .author .avatar a:first-child {
    margin-left: 0;
}

.meta-wrap .author img {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    border: 4px solid #fff;
}

.meta-wrap .author .name .sep {
    margin-right: 3px;
}

.meta-wrap .author .name .sep.last {
    margin-left: 3px;
}

.meta-wrap .author > .avatar {
    margin-right: 15px;
}

.meta-wrap.single {
    max-width: 600px;
}

.meta-wrap.single h1 {
    margin: 0 0 5px;
}

.meta-wrap.compact .author > .name {
    width: 95px;
    line-height: 1.3;
}

.meta-wrap.compact .author .name .sep.last {
    margin-left: 0;
}

.link-block {
    position: relative;
    border-top: 1px solid #e9e9ee;
    padding: 30px 0;
}

.link-block:hover,
.link-block-normal:hover {
    color: #3b3b3b;
}

.link-block:first-child {
    border-top: 0;
}

.link-block > div {
    position: relative;
    z-index: 9;
}

.link-block::after {
    content: '';
    width: calc(100% + 60px);
    height: 100%;
    background: none;
    position: absolute;
    left: 50%;
    top: 50%;
    z-index: 1;
    transform: translate(-50%, -50%);
    transition: all 0.3s ease 0s;
}

.link-block:hover::after {
    background: #f4f4f4;
}

.as-sep {
    border-top: 1px solid #e9e9ee;
    padding: 30px 0 0;
    margin: 0 0 25px;
}

.as-sep-after::after {
    content: '';
    display: block;
    width: 80px;
    height: 1px;
    background: #e20000;
    margin: 20px 0 0;
}

.rating-wrap {
	font-size: 0;
	margin: 0 0 15px;
	position: relative;
}

.rating-wrap > p {
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
    font-weight: 700;
	margin: 0 0 0 10px;
}

.rating-wrap > p a {
    color: #ec2028;
    text-decoration: none;
}

.rating-wrap .rating,
.rating-wrap .rating-stars::before {
	display: inline-block;
	vertical-align: middle;
	background: url('img/icon-stars.svg') no-repeat scroll 0 0 transparent;
	width: 91px;
	height: 18px;
}

.rating-wrap .rating-stars {
	overflow: hidden;
}

.rating-wrap .rating-stars::before {
	content: '';
	background-image: url('img/icon-stars-hover.svg');
}

.info-box {
    margin: 0 0 15px;
}

.info-box h2 {
    margin: 0 0 10px;
}

.info-box .info {
    border-top: 1px solid #e7e7e7;
    border-bottom: 1px solid #e7e7e7;
    padding: 10px 0;
}

.info-box .info a,
.info-box .info p {
    display: block;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    position: relative;
    padding: 0 0 0 27px;
    margin: 0;
}

.info-box .info svg {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}

.info-box .info svg.menu-icon {
    top: -3px;
}

.info-box .price {
    font-weight: 500;
}

.info-box .price span {
    color: #afafaf;
}

.notice {
    font-size: 14px;
    font-weight: 500;
    max-width: 450px;
}

.notice p {
    margin: 0 0 5px;
}

.notice a {
    color: #ec2028;
    text-decoration: none;
}

.as-title {
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    background: #3b3b3b;
    padding: 22px 25px;
    margin: 0;
}

.as-link {
    display: block;
    background: #fafafa;
    padding: 25px;
    border-bottom: 1px solid #e7e7e7;
}

.as-link:hover {
    background: #ffffff;
    color: #3b3b3b;
}

.as-link .rating-wrap > p:last-child,
.acf-map .info-box .rating-wrap > p:last-child {
    color: #e20000;
}

.as-link .info-box {
    margin: 0;
}

.as-link .info {
    border: 0;
    padding: 0;
}

.has-featured > .flex:first-child {
    width: 100%;
}

.has-featured > .flex:first-child .mb-15 > p {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
	text-overflow: ellipsis;
	overflow: hidden;
}

.has-featured > .flex:first-child .img-wrap {
    width: 58%;
}

.has-featured > .flex:first-child .meta-wrap {
    width: 38%;
}

.has-featured > .flex:first-child .meta-wrap h3 {
    font-size: 38px;
}

.has-featured > .flex:first-child .meta-wrap.compact .author > .name {
    width: auto;
}

.has-featured > .flex:first-child .meta-wrap.compact .author .name .sep.last {
    margin-left: 3px;
}

/*------------------------------------*\
    FORMS
\*------------------------------------*/

.input,
.search-input,
.wpcf7-text,
select.wpcf7-select,
div.wpcf7-select a,
.wpcf7-textarea,
.chosen-container-single .chosen-single {
    font-size: 16px;
    line-height: 1.4;
    color: #3b3b3b;
    border: 1px solid #fff;
    outline: 0;
    background: #fff;
    width: 100%;
    height: 50px;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    -webkit-appearance: none;
    transition: all 0.3s ease 0s;
}

.wpcf7-text:focus,
.wpcf7-textarea:focus {
    outline: 0;
    border: 1px solid #fff;
}

.wpcf7-not-valid {
    color: #df0000;
    border-color: #df0000;
}

.wpcf7-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.wpcf7-textarea {
    resize: vertical;
    height: auto;
}

.submit-wrap {
    overflow: hidden;
}

.submit-wrap span {
    float: right;
    margin: 8px 0 0;
}

.wpcf7-submit {
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
}

.wpcf7-submit:focus,
.wpcf7-submit:active {
    border: 0;
    outline: 0;
}

.wpcf7 .flex p {
    display: inline-block;
    vertical-align: top;
    width: 48%;
}

.wpcf7 p {
    font-size: 14px;
    margin: 0 0 15px;
}

.wpcf7 span.wpcf7-not-valid-tip {
    font-size: 12px;
    color: #df0000;
}

.wpcf7 form .wpcf7-response-output {
    color: #fff;
    border: 1px solid #b02c1b;
    text-align: center;
    margin: 20px 0;
    padding: 9px 0px;
}

.wpcf7 form.invalid .wpcf7-response-output {
    border-color: #df0000;
    background: #df0000;
}

.wpcf7 form.sent .wpcf7-response-output {
    background: #00a651;
}

.flatpickr-mobile:before {
    content: attr(placeholder);
}

.flatpickr-mobile:focus[value]:not([value=""]):before,
input[type="hidden"][value]:not([value=""]) + .flatpickr-mobile:before {
    display: none;
}

#sort_chosen {
	min-width: 200px;
}

#sort_chosen .chosen-single {
	font-size: 14px;
	border: 1px solid #e7e7e7;
	height: 40px;
	padding: 9px 20px;
	margin: 0;
}

#sort_chosen .chosen-single div {
	top: 17px;
	right: 20px;
}

#sort_chosen .chosen-single div b {
	display: block;
	width: 12px;
	height: 7px;
	background: url('img/arrow-down.png') no-repeat scroll center center transparent;
}

#sort_chosen .chosen-drop {
	height: auto;
	border-color: #e7e7e7;
	padding: 0;
}

#sort_chosen .chosen-drop li:first-child {
	display: none;
}

#sort_chosen .chosen-results li {
	font-size: 14px;
	background: #fff;
}

#sort_chosen .chosen-results li:hover {
	background: #e7e7e7;
}

select#sort {
	font-size: 14px;
	border: 1px solid #e7e7e7;
	padding: 9px 10px;
	height: 40px;
	width: auto;
	min-width: 100px;
	text-align: center;
}

.chosen-container {
    width: 100%;
    position: relative;
    display: inline-block;
    vertical-align: top;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.chosen-container-single .chosen-single {
    display: block;
    position: relative;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    padding: 10px 30px;
}

.chosen-container-single .chosen-single span {
    display: block;
    overflow: hidden;
    margin-right: 26px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chosen-container-single .chosen-single div {
    display: block;
    position: absolute;
    top: 20px;
    right: 20px;
}

.chosen-container-single .chosen-single div b {
    width: 15px;
    height: 9px;
    background-position: -118px -270px;
}

.chosen-container .chosen-drop {
    position: absolute;
    top: 100%;
    z-index: 1010;
    width: 100%;
    border-right: 1px solid #aaa;
    border-left: 1px solid #aaa;
    border-bottom: 1px solid #aaa;
    border-top: 0;
    background: #fff;
    background-clip: padding-box;
    height: 185px;
    padding: 10px 0;
    clip: rect(0, 0, 0, 0);
    -webkit-clip-path: inset(100% 100%);
    clip-path: inset(100% 100%);
}

.chosen-container .chosen-results {
    position: relative;
    overflow-x: hidden;
    overflow-y: auto;
    margin: 0;
    padding: 0;
    -webkit-overflow-scrolling: touch;
}

.chosen-container.chosen-with-drop .chosen-drop {
    clip: auto;
    -webkit-clip-path: none;
    clip-path: none;
}

.chosen-container .chosen-results li {
    display: none;
    margin: 0;
    padding: 15px 20px;
    list-style: none;
    font-size: 18px;
    line-height: 1;
    transition: all 0.3s ease 0s;
    word-wrap: break-word;
    -webkit-touch-callout: none;
}

.chosen-container .chosen-results li.active-result {
    display: list-item;
    cursor: pointer;
}

.chosen-container-single .chosen-search {
    position: relative;
    z-index: 1010;
    margin: 0;
    padding: 3px 4px;
    white-space: nowrap;
}

.chosen-container-single .chosen-search input[type="text"] {
    margin: 1px 0;
    padding: 4px 20px 4px 5px;
    width: 100%;
    height: auto;
    outline: 0;
    border: 1px solid #aaa;
    font-size: 1em;
    font-family: sans-serif;
    line-height: normal;
    border-radius: 0;
}

.chosen-container-single .chosen-drop {
    background-clip: padding-box;
}

.chosen-container-single.chosen-container-single-nosearch .chosen-search {
    position: absolute;
    clip: rect(0, 0, 0, 0);
    -webkit-clip-path: inset(100% 100%);
    clip-path: inset(100% 100%);
}

.widget-form {
    border: 1px solid #ec2028;
    padding: 30px 30px 25px;
}

.widget-form a {
    color: #ec2028;
    text-decoration: underline;
}

.widget-form .input {
    font-size: 13px;
    width: 83%;
    height: 40px;
    border: 1px solid #ec2028;
    padding: 10px 20px;
}

.widget-form .submit {
    width: 17%;
    background: url('img/icon-arrow.png') no-repeat scroll center center #ec2028;
    border: 0;
    outline: 0;
    padding: 10px 5px;
    margin: 0;
    cursor: pointer;
    height: 40px;
}

::-webkit-input-placeholder {
    opacity: 1;
    color: #3b3b3b;
}

:-moz-placeholder { /* Firefox 18- */
    opacity: 1;
    color: #3b3b3b
}

::-moz-placeholder {  /* Firefox 19+ */
    opacity: 1;
    color: #3b3b3b;
}

:-ms-input-placeholder {
    opacity: 1;
    color: #3b3b3b;
}

:placeholder-shown { /* Standard one last! */
    opacity: 1;
    color: #3b3b3b;
}

/* Simplebar */

[data-simplebar] {
    position: relative;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-content: flex-start;
    align-items: flex-start;
    height: 100%;
    padding: 0;
}

.simplebar-wrapper {
    overflow: hidden;
    width: inherit;
    height: inherit;
    max-width: inherit;
    max-height: inherit;
    height: 185px;
}

.simplebar-mask {
    direction: inherit;
    position: absolute;
    overflow: hidden;
    padding: 0;
    margin: 0;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    width: auto !important;
    height: auto !important;
    z-index: 0;
}

.simplebar-offset {
    direction: inherit !important;
    box-sizing: inherit !important;
    resize: none !important;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    padding: 0;
    margin: 0;
    -webkit-overflow-scrolling: touch;
}

.simplebar-content-wrapper {
    direction: inherit;
    box-sizing: border-box !important;
    position: relative;
    display: block;
    height: 100%; /* Required for horizontal native scrollbar to not appear if parent is taller than natural height */
    width: auto;
    visibility: visible;
    max-width: 100%; /* Not required for horizontal scroll to trigger */
    max-height: 100%; /* Needed for vertical scroll to trigger */
    scrollbar-width: none;
}

.simplebar-content-wrapper::-webkit-scrollbar,
.simplebar-hide-scrollbar::-webkit-scrollbar {
    display: none;
}

.simplebar-content:before,
.simplebar-content:after {
    content: ' ';
    display: table;
}

.simplebar-placeholder {
    max-height: 100%;
    max-width: 100%;
    width: 100%;
    pointer-events: none;
}

.simplebar-height-auto-observer-wrapper {
    box-sizing: inherit !important;
    height: 100%;
    width: 100%;
    max-width: 1px;
    position: relative;
    float: left;
    max-height: 1px;
    overflow: hidden;
    z-index: -1;
    padding: 0;
    margin: 0;
    pointer-events: none;
    flex-grow: inherit;
    flex-shrink: 0;
    flex-basis: 0;
}

.simplebar-height-auto-observer {
    box-sizing: inherit;
    display: block;
    opacity: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 1000%;
    width: 1000%;
    min-height: 1px;
    min-width: 1px;
    overflow: hidden;
    pointer-events: none;
    z-index: -1;
}

.simplebar-track {
    background: #dfdfdf;
    z-index: 1;
    position: absolute;
    right: 0;
    bottom: 0;
    pointer-events: none;
    overflow: hidden;
}

[data-simplebar].simplebar-dragging .simplebar-content {
    pointer-events: none;
    user-select: none;
    -webkit-user-select: none;
}

[data-simplebar].simplebar-dragging .simplebar-track {
    pointer-events: all;
}

.simplebar-scrollbar {
    position: absolute;
    right: 0;
    width: 7px;
    min-height: 10px;
}

.simplebar-scrollbar:before {
    position: absolute;
    content: '';
    background: #808080;
    left: 0;
    right: 0;
    opacity: 1;
    transition: opacity 0.2s linear;
}

.simplebar-scrollbar.simplebar-visible:before {
    /* When hovered, remove all transitions from drag handle */
    opacity: 1;
    transition: opacity 0s linear;
}

.simplebar-track.simplebar-vertical {
    top: 8px;
    right: 10px;
    width: 7px;
    border-radius: 10px;
    margin: 0 0 10px;
}

.simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
    top: 0;
    bottom: 0;
}

.simplebar-track.simplebar-horizontal {
    left: 0;
    height: 11px;
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar:before {
    height: 100%;
    left: 2px;
    right: 2px;
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
    right: auto;
    left: 0;
    top: 2px;
    height: 7px;
    min-height: 0;
    min-width: 10px;
    width: auto;
}

/* Rtl support */
[data-simplebar-direction='rtl'] .simplebar-track.simplebar-vertical {
    right: auto;
    left: 0;
}

.hs-dummy-scrollbar-size {
    direction: rtl;
    position: fixed;
    opacity: 0;
    visibility: hidden;
    height: 500px;
    width: 500px;
    overflow-y: hidden;
    overflow-x: scroll;
}

.simplebar-hide-scrollbar {
    position: fixed;
    left: 0;
    visibility: hidden;
    overflow-y: scroll;
    scrollbar-width: none;
}

.scrollbar.large {
    padding: 0 60px 0 0;
}

.scrollbar.large .simplebar-track.simplebar-vertical,
.scrollbar.large .simplebar-scrollbar {
    width: 15px;
}

/* Tooltip */

.tooltip {
    display: inline-block;
    vertical-align: top;
    font-size: 12px;
    color: #fff;
    text-align: center;
    background: #55555a;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    cursor: pointer;
    margin: 1px 0 0 4px;
}

.tooltip-top {
	display: inline-block;
	vertical-align: top;
	margin: 5px 0 0 6px;
	cursor: pointer;
}

.jBox-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,.75);
}

.jBox-wrapper {
    text-align: left;
    box-sizing: border-box;
}

.jBox-closeButton {
    width: 40px;
    height: 40px;
    background: url('img/icon-close-round.png') no-repeat scroll center center transparent;
    position: absolute;
    right: -18px;
    top: -18px;
    cursor: pointer;
}

.jBox-container {
    background: #fff;
    border-radius: 4px;
    position: relative;
    word-break: break-word;
    box-sizing: border-box;
}

.jBox-content {
    font-size: 14px;
    color: #3b3b3b;
    padding: 25px 35px;
    overflow-x: hidden;
    overflow-y: auto;
    position: relative;
    word-break: break-word;
    box-sizing: border-box;
}

.jBox-content img {
    display: block;
    border-radius: 4px;
    margin: 0 0 15px;
}

.jBox-pointer {
    position: absolute;
    overflow: hidden;
    box-sizing: border-box;
}

.jBox-pointer:after {
    content: "";
    width: 15px;
    height: 15px;
    position: absolute;
    background: #55555a;
    transform: rotate(45deg);
    box-sizing: border-box;
}

.jBox-pointer-bottom,
.jBox-pointer-top {
    width: 30px;
    height: 12px;
}

.jBox-pointer-top {
    top: 0;
}

.jBox-pointer-bottom {
    bottom: 0;
}

.jBox-pointer-top::after {
    left: 5px;
    top: 6px;
}

.jBox-pointer-bottom::after {
    left: 7px;
    bottom: 7px;
}

.jBox-pointerPosition-bottom .jBox-content {
	background: #55555a;
	color: #fff;
	padding: 7px 12px;
}

/*------------------------------------*\
    CLASSES
\*------------------------------------*/

.gap { justify-content: initial; }

.gap-1 { gap: 0 1%; }

.gap-2 { gap: 0 2.5%; }

.gap-3 { gap: 0 3%; }

.gap-4 { gap: 0 4%; }

.gap-5 { gap: 0 5%; }

.gap-6 { gap: 0 6%; }

.gap-7 { gap: 0 7%; }

.gap-8 { gap: 0 8%; }

.gap-9 { gap: 0 9%; }

.height-full { height: 100%; }

.width-auto { width: auto; }

.width-1  { width: 1%; }

.width-2  { width: 2%; }

.width-3  { width: 3%; }

.width-4  { width: 4%; }

.width-5  { width: 5%; }

.width-6  { width: 6%; }

.width-7  { width: 7%; }

.width-8  { width: 8%; }

.width-9  { width: 9%; }

.width-10 { width: 10%; }

.width-11 { width: 11%; }

.width-12 { width: 12%; }

.width-13 { width: 13%; }

.width-14 { width: 14%; }

.width-15 { width: 15%; }

.width-16 { width: 16%; }

.width-17 { width: 17%; }

.width-18 { width: 18%; }

.width-19 { width: 19%; }

.width-20 { width: 20%; }

.width-21 { width: 21%; }

.width-22 { width: 22%; }

.width-23 { width: 23%; }

.width-24 { width: 24%; }

.width-25 { width: 25%; }

.width-26 { width: 26%; }

.width-27 { width: 27%; }

.width-28 { width: 28%; }

.width-29 { width: 29%; }

.width-30 { width: 30%; }

.width-31 { width: 31%; }

.width-32 { width: 32%; }

.width-33 { width: 33%; }

.width-34 { width: 34%; }

.width-35 { width: 35%; }

.width-36 { width: 36%; }

.width-37 { width: 37%; }

.width-38 { width: 38%; }

.width-39 { width: 39%; }

.width-40 { width: 40%; }

.width-41 { width: 41%; }

.width-42 { width: 42%; }

.width-43 { width: 43%; }

.width-44 { width: 44%; }

.width-45 { width: 45%; }

.width-46 { width: 46%; }

.width-47 { width: 47%; }

.width-48 { width: 48%; }

.width-49 { width: 49%; }

.width-50 { width: 50%; }

.width-51 { width: 51%; }

.width-52 { width: 52%; }

.width-53 { width: 53%; }

.width-54 { width: 54%; }

.width-55 { width: 55%; }

.width-56 { width: 56%; }

.width-57 { width: 57%; }

.width-58 { width: 58%; }

.width-59 { width: 59%; }

.width-60 { width: 60%; }

.width-61 { width: 61%; }

.width-62 { width: 62%; }

.width-63 { width: 63%; }

.width-64 { width: 64%; }

.width-65 { width: 65%; }

.width-66 { width: 66%; }

.width-67 { width: 67%; }

.width-68 { width: 68%; }

.width-69 { width: 69%; }

.width-70 { width: 70%; }

.width-71 { width: 71%; }

.width-72 { width: 72%; }

.width-73 { width: 73%; }

.width-74 { width: 74%; }

.width-75 { width: 75%; }

.width-76 { width: 76%; }

.width-77 { width: 77%; }

.width-78 { width: 78%; }

.width-79 { width: 79%; }

.width-80 { width: 80%; }

.width-81 { width: 81%; }

.width-82 { width: 82%; }

.width-83 { width: 83%; }

.width-84 { width: 84%; }

.width-85 { width: 85%; }

.width-86 { width: 86%; }

.width-87 { width: 87%; }

.width-88 { width: 88%; }

.width-89 { width: 89%; }

.width-90 { width: 90%; }

.width-91 { width: 91%; }

.width-92 { width: 92%; }

.width-93 { width: 93%; }

.width-94 { width: 94%; }

.width-95 { width: 95%; }

.width-96 { width: 96%; }

.width-97 { width: 97%; }

.width-98 { width: 98%; }

.width-99 { width: 99%; }

.width-100 { width: 100%; }

.ml-auto { margin-left: auto; }

.ml-20 { margin-left: 20px; }

.mr-15 { margin-right: 15px; }

.mr-20 { margin-right: 20px; }

.mr-25 { margin-right: 25px; }

.mt-0 { margin-top: 0; }

.mt-5 { margin-top: 5px; }

.mt-10 { margin-top: 10px; }

.mt-15 { margin-top: 15px; }

.mt-20 { margin-top: 20px; }

.mt-25 { margin-top: 25px; }

.mt-30 { margin-top: 30px; }

.mt-35 { margin-top: 35px; }

.mt-40 { margin-top: 40px; }

.mt-45 { margin-top: 45px; }

.mt-50 { margin-top: 50px; }

.mt-55 { margin-top: 55px; }

.mt-60 { margin-top: 60px; }

.mt-65 { margin-top: 65px; }

.mt-70 { margin-top: 70px; }

.mt-75 { margin-top: 75px; }

.mt-80 { margin-top: 80px; }

.mt-85 { margin-top: 85px; }

.mt-90 { margin-top: 90px; }

.mt-95 { margin-top: 95px; }

.mt-100 { margin-top: 100px; }

.mb-0 { margin-bottom: 0; }

.mb-5 { margin-bottom: 5px; }

.mb-7 { margin-bottom: 7px; }

.mb-10 { margin-bottom: 10px; }

.mb-12 { margin-bottom: 12px; }

.mb-15 { margin-bottom: 15px; }

.mb-20 { margin-bottom: 20px; }

.mb-25 { margin-bottom: 25px; }

.mb-30 { margin-bottom: 30px; }

.mb-35 { margin-bottom: 35px; }

.mb-40 { margin-bottom: 40px; }

.mb-45 { margin-bottom: 45px; }

.mb-50 { margin-bottom: 50px; }

.mb-55 { margin-bottom: 55px; }

.mb-60 { margin-bottom: 60px; }

.mb-65 { margin-bottom: 65px; }

.mb-70 { margin-bottom: 70px; }

.mb-75 { margin-bottom: 75px; }

.mb-80 { margin-bottom: 80px; }

.mb-85 { margin-bottom: 85px; }

.mb-90 { margin-bottom: 90px; }

.mb-95 { margin-bottom: 95px; }

.mb-100 { margin-bottom: 100px; }

.pt-0 { padding-top: 0; }

.pt-5 { padding-top: 5px; }

.pt-10 { padding-top: 10px; }

.pt-15 { padding-top: 15px; }

.pt-20 { padding-top: 20px; }

.pt-25 { padding-top: 25px; }

.pt-30 { padding-top: 30px; }

.pt-35 { padding-top: 35px; }

.pt-40 { padding-top: 40px; }

.pt-45 { padding-top: 45px; }

.pt-50 { padding-top: 50px; }

.pt-55 { padding-top: 55px; }

.pt-60 { padding-top: 60px; }

.pt-65 { padding-top: 65px; }

.pt-70 { padding-top: 70px; }

.pt-75 { padding-top: 75px; }

.pt-80 { padding-top: 80px; }

.pt-85 { padding-top: 85px; }

.pt-90 { padding-top: 90px; }

.pt-95 { padding-top: 95px; }

.pt-100 { padding-top: 100px; }

.pb-0 { padding-bottom: 0; }

.pb-5 { padding-bottom: 5px; }

.pb-10 { padding-bottom: 10px; }

.pb-15 { padding-bottom: 15px; }

.pb-20 { padding-bottom: 20px; }

.pb-25 { padding-bottom: 25px; }

.pb-30 { padding-bottom: 30px; }

.pb-35 { padding-bottom: 35px; }

.pb-40 { padding-bottom: 40px; }

.pb-45 { padding-bottom: 45px; }

.pb-50 { padding-bottom: 50px; }

.pb-55 { padding-bottom: 55px; }

.pb-60 { padding-bottom: 60px; }

.pb-65 { padding-bottom: 65px; }

.pb-70 { padding-bottom: 70px; }

.pb-75 { padding-bottom: 75px; }

.pb-80 { padding-bottom: 80px; }

.pb-85 { padding-bottom: 85px; }

.pb-90 { padding-bottom: 90px; }

.pb-95 { padding-bottom: 95px; }

.pb-100 { padding-bottom: 100px; }


/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/

@media only screen and (max-width: 1280px) {
    .slick-prev {
        left: 0;
    }

    .slick-next {
        right: 0;
    }
}

@media only screen and (max-width: 1140px) {

}

@media only screen and (max-width: 1040px) {
    .mobile-1040-width-100 {
        width: 100%;
    }

    .mobile-1040-width-65 {
        width: 65%;
    }

    .mobile-1040-width-35 {
        width: 35%;
    }

    .mobile-1040-text-left {
        text-align: left;
    }

    .as-link .rating-wrap > p:last-child {
        display: block;
        margin: 5px 0 0;
    }
}

@media only screen and (max-width: 960px) {
    .mobile-960-width-100 {
        width: 100%;
    }

    .nav li {
        margin: 0 7px;
    }
}

@media only screen and (max-width: 800px) {
    .mobile-800-hidden,
    .nav li:hover .sub-menu,
    .mobile-800-menu-title ~ div,
    .link-block::after,
    .directory .as-link,
	#sort_chosen .chosen-single div {
        display: none;
    }
    
    .btn-menu,
    .header .menu-item-has-children > a > span.toggle,
    .desktop-hidden {
        display: block;
    }
        
    .nav li.sep-right::after,
    .nav > ul > li > a:hover::after,
    .nav li:hover .sub-menu,
    .header .btn.red {
        display: none;
    }
		
    body.active-header .btn.red {
        display: block;
        position: fixed;
        bottom: 20px;
        width: 94%;
        left: 3%;
        margin: 0;
        padding: 10px 20px;
    }

    body.active-header::after {
        content: '';
        background: #fff;
        opacity: 1;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    .nav .btn-menu {
        display: block;
        background: url('img/icon-open.png') no-repeat scroll center center transparent;
        background-size: cover;
        width: 30px;
        height: 30px;
        position: absolute;
        right: 15px;
        top: 16px;
        cursor: pointer;
        border: 0;
        outline: 0;
        padding: 0;
    }

    .nav.active .btn-menu {
        background-image: url('img/icon-close.png');
        background-size: 90%;
    }

    .nav ul {
        display: none;
        position: absolute;
        left: 0;
        top: 60px;
        width: 100%;
        height: auto;
        padding: 0;
        z-index: 99;
        background: #fff;
        text-align: left;
    }

    .nav.active > ul {
        display: block;
    }
	
    .nav > ul > li {
        display: block;
        width: 100%;
        height: auto;
        background: #fff;
        padding: 0;
        margin: 0;
        text-align: left;
        border-bottom: 1px solid #e7e7e7;
    }

    .header a > span.toggle {
        background: url('img/icon-plus.png') no-repeat scroll center center transparent;
        background-size: 30px;
        width: 60px;
        height: 54px;
        position: absolute;
        right: 0;
        top: 0;
        z-index: 999;
    }

    .header a > span.toggle.active {
        background-image: url('img/icon-minus.png');
    }

    .header .nav .sub-menu {
        position: relative;
        width: 100%;
        border: 0;
        padding: 0;
        margin: 0;
        border-radius: 0;
        border: 0;
        text-align: left;
        box-shadow: none;
    }

    .header .nav .sub-menu li {
        margin: 0;
        padding: 0;
        border-top: 1px solid #e7e7e7;
        border-bottom: 0;
    }

    .header .nav .sub-menu li a {
        display: block;
        padding: 16px 30px;
        margin: 0;
    }

    .header .nav .sub-menu li a.has-svg {
        padding: 10px 30px 10px 60px;
    }

    .nav > ul > li > a {
        display: block;
        line-height: 1.2;
        padding: 16px 15px;
        height: auto;
    }

    .nav > ul > li.profile > a {
        padding: 8px 15px;
    }

    .nav li.sep-right {
        margin-right: 0;
    }

    .nav > ul > li > a > svg {
        position: absolute;
        right: 15px;
        top: 22px;
    }

    .footer {
        padding: 0;
    }

    .footer > .wrapper {
        padding: 40px 0 0;
    }

    .footer > .wrapper > .flex {
        padding-left: 15px;
        padding-right: 15px;
    }

    .footer .bottom {
        margin: 30px 0 0;
    }

    .header-wrap.size-550 {
        height: 350px;
        padding: 50px 0 0;
    }

    .header-wrap .flex.bottom {
        align-items: center;
    }

    .font-size-48 {
        font-size: 34px;
    }

    h1 {
        font-size: 24px;
    }

    .widget-form .input {
        font-size: 16px;
    }

    .footer ul a {
        font-size: 14px;
    }
    
    .section[style*="padding-top: 60px;"] {
        padding-top: 30px !important;
    }
	
	section[style*="padding-top: 120px;"] {
        padding-top: 80px !important;
    }

    .section[style*="padding-bottom: 60px;"] {
        padding-bottom: 30px !important;
    }
	
	.info-box .info .mobile-800-font-size-0 {
		margin-right: 12px;
	}
	
	.info-box .info .mobile-800-font-size-0 > a {
		font-size: 0;
		padding: 0;
	}
	
	.info-box .info .mobile-800-font-size-0 > a svg {
		position: relative;
	}

    .mobile-800-text-left {
        text-align: left;
    }

    .mobile-800-text-center {
        text-align: center;
    }
	
	.mobile-800-right {
		float: right;
	}
	
	a + .mobile-800-right-end {
		float: right;
	}
	
	.mobile-640-width-auto {
		width: auto;
	}
    
    .mobile-800-width-100,
    .has-featured > .flex:first-child .img-wrap,
    .has-featured > .flex:first-child .meta-wrap {
        width: 100%;
    }
	
    .mobile-800-width-65 {
        width: 65%;
    }

    .mobile-800-width-50 {
        width: 50%;
    }

    .mobile-800-width-35 {
        width: 35%;
    }
    
    .mobile-800-width-48 {
        width: 48%;
    }

    .mobile-800-mt-15 {
        margin-top: 15px;
    }

    .mobile-800-mt-10 {
        margin-top: 10px;
    }

    .mobile-800-mt-5 {
        margin-top: 5px;
    }
	
	.mobile-800-mt-0 {
		margin-top: 0;
	}
    
    .mobile-800-mb-20 {
        margin-bottom: 20px;
    }

    .mobile-800-mb-15,
    figure.wp-block-image,
    p,
    article ul {
        margin-bottom: 15px;
    }

    .mobile-800-mb-10,
    article ul li {
        margin-bottom: 10px;
    }

    .mobile-800-mb-0 {
        margin-bottom: 0;
    }

    .mobile-800-pt-0 {
        padding-top: 0;
    }

    .mobile-800-order-1 {
        order: 1;
    }

    .mobile-800-order-2 {
        order: 2;
    }

    .mobile-800-order-3 {
        order: 3;
    }

    .mobile-800-order-4 {
        order: 4;
    }

    .mobile-800-order-5 {
        order: 5;
    }

    .mobile-800-order-6 {
        order: 6;
    }

    .mobile-800-as-sep {
        border-bottom: 1px solid #616161;
        padding-bottom: 15px;
        margin-bottom: 15px;
    }

    .mobile-800-menu-title {
        cursor: pointer;
        position: relative;
    }

    .mobile-800-menu-title::after {
        content: '';
        background: url('img/icon-plus-small.png') no-repeat scroll center center transparent;
        width: 11px;
        height: 11px;
        position: absolute;
        right: 0;
        top: 4px;
    }

    .mobile-800-menu-title.active::after {
        background-image: url('img/icon-minus-small.png');
    }

    .flex.mobile-800-flex-start {
        align-items: flex-start;
    }

    .flex.mobile-800-justify-start {
        justify-content: flex-start;
    }

    .img-wrapper.small {
        margin-left: 0;
    }

    .img-wrapper.srcset img {
        width: auto;
        max-width: 100%;
        min-height: 35px;
        margin: 0 20px 20px 0;
    }

    .social-wrap a {
        margin: 0 20px 15px 0;
    }

    .flex.as-sep {
        padding-top: 15px;
        margin-top: 0;
    }

    .footer .menu-inline:not(.mobile-800-menu-inline) ul li {
        display: block;
        margin: 0;
    }

    .as-menu-list {
        column-count: 1;
    }

    .carousel .slide > figure,
    .carousel .slide > img,
    .carousel .slide > iframe {
        max-width: 100%;
    }

    .arrows-inside .slick-prev {
        left: 20px;
    }

    .arrows-inside .slick-next {
        right: 20px;
    }

    .info-box .info .price {
        padding-left: 0;
    }

    .directory {
        position: relative;
    }

    .directory .width-25 {
        width: 100%;
        position: absolute;
        left: 0;
        bottom: 0;
        z-index: 8;
    }

    .directory .as-title {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
    }

    .meta-wrap.compact .author > .name {
        width: auto;
    }

    .meta-wrap.compact .author .name .sep.last {
        margin-left: 3px;
    }
	
	.has-featured > .flex:first-child .img-wrap-medium.normal,
	.img-wrap-medium.normal {
		height: 300px;
	}
	
	article.mt-40 {
		border-bottom: 1px solid #e7e7e7;
		margin-top: 30px;
	}
	
	article.mt-40 .carousel {
		margin-bottom: 30px;
	}
	
	.btn-wrap .btn,
	.btn-wrap a.img,
	.text-right > .btn-wrap .btn {
		margin: 10px 10px 5px 0;
	}
	
	article .link {
		display: inline-block;
		margin-bottom: 0;
	}

	article .link + .carousel {
		margin-top: 5px;
	}
	
	#sort_chosen {
		min-width: 100px;
	}
	
	#sort_chosen .chosen-single {
		padding: 9px 10px;
	}
	
	#sort_chosen .chosen-single span {
		margin-right: 0;
	}
	
	#sort_chosen .chosen-results li {
		padding: 15px 10px;
	}
	
	.social-wrap.share.first a {
		margin-bottom: 0;
	}
}

@media only screen and (max-width: 768px) {

}

@media only screen and (max-width: 640px) {
    .mobile-640-width-100 {
        width: 100%;
    }
	
	.mobile-640-max-width-200 {
		max-width: 200px;
	}

    .mobile-640-mb-20 {
        margin-bottom: 20px;
    }
	
	.mobile-640-mb-8 {
        margin-bottom: 8px;
    }
	
	.mobile-640-mr-12 {
		margin-right: 12px;
	}

    .acf-map .info-box {
        width: 100%;
    }

    .acf-map .info-box .rating-wrap > p:last-child {
        display: block;
        margin: 5px 0 0;
    }

    .gm-style .gm-style-iw-c {
        max-width: 90% !important;
    }
}

@media only screen and (max-width: 480px) {
    .mobile-480-width-100 {
        width: 100%;
    }

    .social-wrap a {
        width: 25%;
        margin: 0 0 15px 0;
    }
	
    .social-wrap.share a,
    .social-wrap.normal a,
	.social-wrap.white a {
        width: auto;
    }

   .meta-wrap .mobile-480-author > .avatar {
        margin-right: 2%;
    }

    .meta-wrap .mobile-480-author > .name {
        width: 55%;
    }
}

@media only screen and (max-width: 320px) {

}

/*------------------------------------*\
    MISC
\*------------------------------------*/

::selection {
    background: #04A4CC;
    color: #FFF;
    text-shadow: none;
}

::-webkit-selection {
    background: #04A4CC;
    color: #FFF;
    text-shadow: none;
}

::-moz-selection {
    background: #04A4CC;
    color: #FFF;
    text-shadow: none;
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
    margin: 5px 20px 20px 0;
}

.aligncenter,
div.aligncenter {
    display: block;
    margin: 5px auto 5px auto;
}

.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.alignright {
    float: right;
    margin: 5px 0 20px 20px;
}

a img.alignnone {
    margin: 5px 20px 20px 0;
}

a img.alignleft {
    float: left;
    margin: 5px 20px 20px 0;
}

a img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.wp-caption {
    background: #FFF;
    border: 1px solid #F0F0F0;
    max-width: 96%;
    padding: 5px 3px 10px;
    text-align: center;
}

.wp-caption.alignnone {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignleft {
    margin: 5px 20px 20px 0;
}

.wp-caption.alignright {
    margin: 5px 0 20px 20px;
}

.wp-caption img {
    border: 0 none;
    height: auto;
    margin: 0;
    max-width: 98.5%;
    padding: 0;
    width: auto;
}

.wp-caption .wp-caption-text,
.gallery-caption {
    font-size: 11px;
    line-height: 17px;
    margin: 0;
    padding: 0 4px 5px;
}

.wp-block-image {
    margin: 0 0 30px;
}

.wp-block-image img {
    width: 100%;
}

.wp-block-image :where(figcaption) {
    font-size: 12px;
    color: #656568;
    margin: 10px 0 0;
}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
    * {
        background: transparent !important;
        color: #000 !important;
        box-shadow: none !important;
        text-shadow: none !important;
    }
    
    a,
    a:visited {
        text-decoration: underline;
    }
    
    a[href]:after {
        content: " (" attr(href) ")";
    }
    
    abbr[title]:after {
        content: " (" attr(title) ")";
    }
    
    .ir a:after,
    a[href^="javascript:"]:after,
    a[href^="#"]:after {
        content: "";
    }
    
    pre,blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }
    
    thead {
        display: table-header-group;
    }
    
    tr,img {
        page-break-inside: avoid;
    }
    
    img {
        max-width: 100% !important;
    }
    
    @page {
        margin: 0.5cm;
    }
    
    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }
    
    h2,
    h3 {
        page-break-after: avoid;
    }
}