/** 
 * Author: Shadow Themes
 * Author URL: http://shadow-themes.com
 */

nav.ashade-mobile-menu,
#ashade-header .ashade-nav-block .ashade-mobile-header,
.ashade-mobile-title-wrap {
	display: none;
}
body .hide-on-desktop,
body section.ashade-section.hide-on-desktop {
	display: none;
}

/* Content Resizer */
@media only screen and (max-width: 1800px) {
    .ashade-content {
		width: calc(100% - 352px);
    }
	.ashade-more-categories {
		max-width: calc(100% - 352px);
	}
	body.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap,
    body.ashade-layout--vertical:not(.ashade-albums-template--slider) .ashade-page-title-wrap {
        left: 70px;
    }
    body.ashade-layout--vertical .ashade-back-wrap {
        left: calc(100% - 126px);
    }
    body:not(.ashade-albums-template--slider) .ashade-page-title-wrap h1 {
        font-size: 50px;
        line-height: 55px;
    }
	body:not(.ashade-albums-template--slider) .ashade-page-title-wrap h1 span {
        font-size: 14px;
        line-height: 18px;
	}
    body:not(.ashade-albums-template--slider) .ashade-page-title-wrap h1 > span {
		margin: 0 0 6px 0;
    }
	.ashade-page-title-wrap:before {
		top: 21px;
	}
	.ashade-layout--horizontal .ashade-protected-inner .ashade-page-title-wrap:before {
		top: 65px;
	}
}

@media only screen and (max-width: 1679px) {
	.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap,
    body.ashade-layout--vertical:not(.ashade-albums-template--slider) .ashade-page-title-wrap {
        left: 50px;
    }
    body.ashade-layout--vertical .ashade-back-wrap {
        left: calc(100% - 126px);
    }
}

@media only screen and (max-width: 1600px) {
	.ashade-content {
		width: calc(100% - 312px);
	}
	.ashade-more-categories {
		max-width: calc(100% - 312px);
	}
	.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap,
    body.ashade-layout--vertical:not(.ashade-albums-template--slider) .ashade-page-title-wrap {
        left: 40px;
    }
    body.ashade-layout--vertical .ashade-back-wrap {
        left: calc(100% - 116px);
    }
}
@media only screen and (max-width: 1200px) {
	.ashade-content {
		width: calc(100% - 272px);
	}
	.ashade-more-categories {
		max-width: calc(100% - 272px);
	}
	.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap,
    body.ashade-layout--vertical:not(.ashade-albums-template--slider) .ashade-page-title-wrap {
        left: 30px;
    }
    body.ashade-layout--vertical .ashade-back-wrap {
        left: calc(100% - 106px);
    }
}

@media only screen and (max-width: 782px) {
	body.admin-bar header#ashade-header {
		top: 46px;
	}
	body.admin-bar.ashade-smooth-scroll .ashade-header-holder {
		margin-top: 46px;
	}
	.admin-bar .ashade-content-wrap {
		min-height: calc(100vh - 46px);
	}
	html.has-admin-bar {
		min-height: calc(100% - 46px);
	}
}
@media only screen and (max-width: 960px) {
	.ashade-albums-template--ribbon .ashade-albums-carousel-wrap .ashade-albums-carousel.is-vertical,
	.ashade-content {
		width: calc(100% - 176px);
		margin: auto 40px auto auto;
	}
	body.ashade-layout--horizontal .ashade-content {
		margin: auto;
	}
	.ashade-more-categories {
		max-width: calc(100% - 176px);
	}
	body.ashade-home-template .ashade-content {
		width: calc(100% - 280px);
		margin: auto;
	}
}

/* Laptop Styles */
@media only screen and (max-width: 1440px) {
	body {
		font-size: 0.9em;
	}
	body .hide-on-laptop,
	body section.ashade-section.hide-on-laptop {
		display: none;
	}
	.ashade-filter-wrap a {
		margin: 0 15px;
	}
	
	/* --- Grid --- */
	body .elementor-container.elementor-column-gap-default .elementor-row {
		margin: 0 -15px;
		width: calc(100% + 30px);
	}
	body .elementor-container.elementor-column-gap-default .elementor-row .elementor-container.elementor-column-gap-default .elementor-row {
		width: calc(100% + 30px);
	}
	body .elementor-column-gap-default > .elementor-row > .elementor-column > .elementor-element-populated {
		padding: 0 15px;
	}

	.ashade-row {
		display: flex;
		flex-direction: row;
		margin: 0 -15px;
	}
	.ashade-col {
		margin: 0 15px;
	}

	.ashade-col.col-12 {
		width: calc(100% - 30px);
	}
	.ashade-col.col-9 {
		width: calc(75% - 30px);
	}
	.ashade-col.col-8 {
		width: calc(66.66% - 30px);
	}
	.ashade-col.col-6 {
		width: calc(50% - 30px);
	}
	.ashade-col.col-4 {
		width: calc(33.33% - 30px);
	}
	.ashade-col.col-3 {
		width: calc(25% - 30px);
	}
	.ashade-col.col-2 {
		width: calc(16.665% - 30px);
	}

	section.ashade-section {
		margin-bottom: 120px;
		display: block;
		width: 100%;
	}
	.ashade-content section.ashade-section:last-child {
		margin-bottom: 0;
	}
	
	/* --- Content General --- */
	p.ashade-intro {
		margin-bottom: 60px;
	}
	.ashade-page-title-wrap.is-loaded h1 {
		padding-left: 30px;
	}
	.ashade-page-title-wrap.is-loaded h1 > span {
    	transform: translateX(-30px);
	}
	
	/* --- Contacts Page --- */
	.ashade-contact-details__list li {
		padding-left: 48px;
		min-height: 30px;
	}
	.ashade-contact-icon {
		width: 36px;
		height: 36px;
		border-radius: 18px;
		transform: translateY(-1px);
	}
	.ashade-contact-icon:before {
		transform: translate(-1px,-1px);
	}
	.asiade-icon--socials.ashade-contact-icon:before {
		transform: translate(-2px,-2px);
	}
	.asiade-icon--phone.ashade-contact-icon:before {
		transform: translate(-2px,-1px);
	}
}

/* Tablet Landscape Styles */
@media only screen and (max-width: 1200px) {
	.ashade-cursor {
		display: none;
	}
	body .hide-on-tablet,
	body .hide-on-tablet-land,
	body section.ashade-section.hide-on-tablet,
	body section.ashade-section.hide-on-tablet-land {
		display: none;
	}
	body .hide-on-desktop,
	body .hide-on-laptop,
	body section.ashade-section.hide-on-desktop,
	body section.ashade-section.hide-on-laptop {
		display: block;
	}
	
	/* --- Grid --- */
	.ashade-row {
		display: flex;
		flex-direction: row;
		margin: 0 -10px;
	}
	.ashade-col {
		margin: 0 10px;
	}

	.ashade-col.col-12 {
		width: calc(100% - 20px);
	}
	.ashade-col.col-9 {
		width: calc(75% - 20px);
	}
	.ashade-col.col-8 {
		width: calc(66.66% - 20px);
	}
	.ashade-col.col-6 {
		width: calc(50% - 20px);
	}
	.ashade-col.col-4 {
		width: calc(33.33% - 20px);
	}
	.ashade-col.col-3 {
		width: calc(25% - 20px);
	}
	.ashade-col.col-2 {
		width: calc(16.665% - 20px);
	}

	form .ashade-row.ashade-small-gap {
		flex-direction: column;
		margin: 0
	}
	form .ashade-row.ashade-small-gap .ashade-col.col-4 {
    	width: 100%;
		margin: 0;
	}
	/* --- Media Grid --- */
	.ashade-grid {
		margin: -15px;
		display: flex;
		flex-wrap: wrap;
	}
	.ashade-grid .ashade-grid-item {
		margin: 15px;
	}
	.ashade-grid-1cols .ashade-grid-item {
		width: calc(100% - 30px);
	}
	.ashade-grid-2cols .ashade-grid-item {
		width: calc(50% - 30px);
	}
	.ashade-grid-3cols .ashade-grid-item {
		width: calc(33.33% - 30px);
	}
	.ashade-grid-4cols .ashade-grid-item {
		width: calc(25% - 30px);
	}
	.ashade-grid-5cols .ashade-grid-item {
		width: calc(20% - 30px);
	}
	
	.ashade-gallery-bricks {
		margin: -15px;
	}
	.ashade-gallery-bricks .ashade-gallery-item {
		margin: 15px;
	}
	.ashade-gallery-bricks.is-1x2 .ashade-gallery-item {
		width: calc(50% - 30px);
	}
	.ashade-gallery-bricks.is-1x2 .ashade-gallery-item:nth-child(3n) {
		width: calc(100% - 30px);
	}
	.ashade-gallery-bricks.is-2x3 .ashade-gallery-item.is-large {
		width: calc(50% - 30px);
	}
	.ashade-gallery-bricks.is-2x3 .ashade-gallery-item.is-small {
		width: calc(33.33% - 30px);
	}

	/* --- Header --- */
	nav.ashade-nav ul.main-menu > li {
		margin: 0 0 0 30px;
	}

	/* --- Grid Filter --- */
	.ashade-filter-wrap {
		margin-bottom: 40px;
	}
	.ashade-filter-wrap a {
		margin: 0 15px;
	}
	
	/* --- Section --- */
	#ashade-home-contacts p.ashade-intro {
		margin-bottom: 50px;
	}
	#ashade-home-works p.ashade-intro,
	section.ashade-section {
		margin-bottom: 100px;
		display: block;
		width: 100%;
	}
	.ashade-content {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	.ashade-content section.ashade-section:last-child {
		margin-bottom: 0;
	}

	/* --- Typography --- */
	.is-dropcap::first-letter,
	h1 {
		font-size: 50px;
		line-height: 55px;
		margin: 0 0 35px 0;
	}
	h1 span {
		font-size: 14px;
		line-height: 18px;
		margin: 0 0 0 0;
	}
	.ashade-albums-slider .ashade-album-item__explore,
	.ashade-home-link span:last-child,
	.ashade-back span:last-child,
	h2 {
		font-size: 35px;
		line-height: 40px;
		margin: 0 0 30px 0;
	}
	h2 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 1px 0;
	}
	.ashade-slider-prev,
	.ashade-slider-next,
	h3 {
		font-size: 30px;
		line-height: 35px;
		margin: 0 0 35px 0;
	}
	h3 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 1px 0;
	}
	h4 {
		font-size: 24px;
		line-height: 29px;
		margin: 0 0 29px 0;
	}
	h4 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 0 0;
	}
	h5 {
		font-size: 20px;
		line-height: 25px;
		margin: 0 0 25px 0;
	}
	h5 span {
		font-size: 10px;
		line-height: 13px;
		margin: 0 0 0 0;
	}
	h6 {
		font-size: 18px;
		line-height: 23px;
		margin: 0 0 23px 0;
	}
	h6 span {
		font-size: 10px;
		line-height: 13px;
		margin: 0 0 0 0;
	}
	.is-dropcap::first-letter {
		margin: 4px 15px 0 0;
	}

	.ashade-slider-prev,
	.ashade-slider-next {
		margin: 0;
		bottom: 60px;
	}
	#ashade-coming-soon h2 {
		font-size: 60px;
		line-height: 65px;
	}
	
	/* --- Elements --- */
	/* Testimonials */
	.ashade-testimonials-grid {
		margin: -20px -15px;
	}
	.ashade-testimonials-grid .ashade-testimonials-item {
		margin: 20px 15px;
		width: calc(33.33% - 30px);
	}
	.ashade-testimonials-grid .ashade-testimonials-item__author {
		position: relative;
		min-height: 80px;
		justify-content: flex-end;
	}
	.ashade-testimonials-grid .ashade-testimonials-item__author--image {
		position: absolute;
		left: 0;
		top: 0;
	}
	.ashade-testimonials-grid .ashade-testimonials-item__author img {
		width: 80px;
		height: auto;
	}
	.ashade-testimonials-grid .ashade-testimonials-item__author--name {
		position: relative;
		z-index: 5;
	}
	.ashade-testimonials-grid .ashade-testimonials-item__content {
		margin: -20px 0 0 0;
	}
	
	/* Services */
	.ashade-services-block {
		padding-top: 100px;
		padding-bottom: 60px;
	}
	.ashade-service-item__content-inner {
		padding: 40px 30px 34px 30px;
	}
	.ashade-service-item .ashade-service-item__image {
		width: calc(40% - 20px);
		box-shadow: none;
	}
	.ashade-service-item .ashade-service-item__content {
		width: calc(60% + 20px);
		box-shadow: 0 0 15px rgba(0,0,0,0.2);
	}
	
	/* Counter */
	.ashade-counter-label {
		font-size: 12px;
		line-height: 18px;
	}
	.ashade-counter-value {
		font-size: 60px;
		line-height: 70px;
	}
	
	/* --- Home Video --- */
	.ashade-home-background video {
		max-width: none;
		max-height: 100vh;
	}
	
	/* --- Maintenance --- */
	.ashade-maintenance-wrap #ashade-contacts-wrap .col-2 {
		display: none;
	}
	.ashade-maintenance-wrap #ashade-contacts-wrap .col-8 {
		width: calc(100% - 20px);
	}
	
	.ashade-albums-carousel-wrap .ashade-album-item__title:before {
		top: 18px;
	}
	
	.ashade-albums-slider-wrap .ashade-album-item__explore span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 1px 0;
	}
	.ashade-albums-slider-wrap .ashade-album-item__explore:before,
	.ashade-albums-slider-wrap .ashade-album-item__title:before {
		top: 18px;
	}
	.ashade-progress-item-wrap {
		padding: 0 20px;
	}

	.ashade-service-card-grid .ashade-service-card {
		width: calc(100% - 40px);
	}
	.ashade-progress-counter {
		font-size: 24px;
		line-height: 29px;
		transform: translateX(3px);
	}
	
	.ahshade-client-toolbar > div {
		padding: 0 5px;
	}
	.ashade-client-item .ahshade-client-toolbar {
		padding-left: 20px;
		padding-right: 20px;
	}
	.ashade-client-buttons--hover .ashade-client-item .ahshade-client-toolbar {
		opacity: 1;
		transform: translateY(0);
	}
}
	
/* Tablet Portrait Styles */
@media only screen and (max-width: 960px) {
	body .hide-on-desktop,
	body .hide-on-laptop,
	body .hide-on-tablet-land,
	body section.ashade-section.hide-on-desktop,
	body section.ashade-section.hide-on-laptop,
	body section.ashade-section.hide-on-tablet-land {
		display: block;
	}
	body .hide-on-tablet-port,
	body section.ashade-section.hide-on-tablet-port {
		display: none;
	}
	body.ashade-layout--vertical .ashade-to-top-wrap {
    	display: none;
	}
	.hide-on-tablet-port.hide-on-phone {
		display: none!important;
	}
	.ashade-row-fullheight {
		min-height: 0!important;
	}
	
	/* --- Media Grid --- */
	#ashade-home-works .ashade-grid-2cols .ashade-grid-item,
	#ashade-home-works .ashade-grid-3cols .ashade-grid-item,
	#ashade-home-works .ashade-grid-4cols .ashade-grid-item,
	#ashade-home-works .ashade-grid-5cols .ashade-grid-item {
		width: calc(50% - 30px);
	}
	
	/* --- Grid --- */
	.ashade-row:not(.ashade-keep-on-tablet) {
		display: flex;
		flex-direction: column;
		margin: 0;
	}
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col {
		margin: 0 0 30px 0;
	}
	form .ashade-row:not(.ashade-keep-on-tablet) .ashade-col {
		margin: 0;
	}
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col:last-child {
		margin: 0;
	}
	.ashade-grid.ashade-small-gap {
		margin: 10px 0;
	}
	
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-12,
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-9, 
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-8, 
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-6, 
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-4, 
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-3, 
	.ashade-row:not(.ashade-keep-on-tablet) .ashade-col.col-2,
	.ashade-small-gap.ashade-grid-1cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-2cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-3cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-4cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-5cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-1cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-2cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-3cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-4cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-5cols .ashade-grid-item {
		width: 100%;
	}

	/* --- Header --- */
	header#ashade-header .ashade-header-inner {
		padding: 30px 40px;
	}
	nav.ashade-nav ul.main-menu > li {
		margin: 0 0 0 30px;
	}
	
	#ashade-header .ashade-nav-block nav {
		display: none;
	}
	#ashade-header .ashade-nav-block .ashade-mobile-header {
		display: block;
	}
	
	.ashade-mobile-header a {
		display: inline-block;
		width: 30px;
		height: 30px;
	}
	.ashade-mobile-menu-button {
		font-size: 32px;
		line-height: 30px;
	}
	a.ashade-aside-toggler {
		margin-left: 15px;
	}
	a.ashade-aside-toggler span {
		top: 16px;
	}
	.ashade-mobile-header a.ashade-mobile-back {
		vertical-align: top;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-right: 12px;
		margin-top: 3px;
	}
	body.no-history .ashade-mobile-header a.ashade-mobile-back {
		display: none;
	}
	body.ashade-layout--vertical.single-ashade-albums.ashade-albums-back.has-history .ashade-back-wrap.ashade-ribbon-return, 
	body.ashade-layout--vertical.single-ashade-albums.ashade-albums-back.has-history .ashade-back-wrap.ashade-slider-return {
		display: none;
	}
	
	
	/* --- Mobile Menu --- */
	nav.ashade-mobile-menu {
		position: fixed;
		right: 0;
		top: 0;
		width: 384px;
		height: 100%;
		background: #000000;
		display: block;
		z-index: 333;
		pointer-events: none;
		transform: translateX(100%);
		transition: transform 0.5s;
	}
	.ashade-mobile-menu-shown nav.ashade-mobile-menu {
		pointer-events: auto;
		transform: translateX(0);
	}
	.ashade-mobile-menu-shown .ashade-menu-overlay {
		opacity: 0.5;
		pointer-events: auto;
	}
	body.ashade-layout--vertical.ashade-mobile-menu-shown .ashade-home-link-wrap.is-loaded,
	body.ashade-layout--vertical.ashade-mobile-menu-shown .ashade-page-title-wrap {
		transform: rotate(-90deg) translateY(-192px);
	}

	body.is-locked.ashade-mobile-menu-shown nav.ashade-mobile-menu {
		pointer-events: none;
	}
	.ashade-mobile-menu-inner {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		overflow-y: scroll;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: flex-start;
	}
	.ashade-mobile-menu-content {
		max-width: 100%;
		padding: 40px 40px;
		margin: auto 0;
		width: 100%;
	}
	nav.ashade-mobile-menu ul {
		padding: 0;
		margin: 0;
	}
	nav.ashade-mobile-menu ul li {
		padding: 0;
		margin: 0;
		list-style: none;
	}
	nav.ashade-mobile-menu ul.main-menu > li {
		padding-top: 10px;
	}
	nav.ashade-mobile-menu ul ul.sub-menu {
		padding: 0 0 0 20px;
	}
	nav.ashade-mobile-menu ul ul.sub-menu li {
		padding: 10px 0 0 20px;
		border-left: 1px solid rgba(255,255,255,0.15);
	}
	nav.ashade-mobile-menu ul ul.sub-menu > li:last-child {
		padding-bottom: 10px;
	}
	nav.ashade-mobile-menu a.ashade-aside-toggler {
		display: none!important;
	}
	nav.ashade-mobile-menu ul.main-menu li a {
		color: rgba(255,255,255,0.5);
		display: block;
	}
	nav.ashade-mobile-menu ul.main-menu > li > a {
		margin-bottom: 10px;
	}
	nav.ashade-mobile-menu ul.main-menu li.current-menu-parent > a,
	nav.ashade-mobile-menu ul.main-menu li.current-menu-item > a,
	nav.ashade-mobile-menu ul.main-menu li.current-menu-ancestor > a {
		color: rgba(255,255,255,1);
	}
	
	a.ashade-mobile-menu-close {
		position: fixed;
		right: 20px;
		top: 20px;
		width: 30px;
		height: 30px;
		z-index: 10;
		display: flex;
		justify-content: center;
		align-items: center;
		transition: opacity 0.3s;
	}
	body.admin-bar a.ashade-mobile-menu-close {
		top: 66px;
	}
	body.is-locked a.ashade-mobile-menu-close {
		opacity: 0;
	}
	a.ashade-mobile-menu-close svg {
		display: block;
		max-width: 100%;
		height: auto;
		margin: auto;
	}
	
	.ashade-aside-shown.ashade-albums-template--ribbon .ashade-albums-carousel-wrap,
	.ashade-aside-shown.ashade-albums-template--slider .ashade-albums-slider-wrap,
	.ashade-aside-shown main.ashade-content-wrap,
	.ashade-aside-shown .ashade-home-wrap,
	.ashade-aside-shown header#ashade-header,
	.ashade-mobile-menu-shown.ashade-albums-template--ribbon .ashade-albums-carousel-wrap,
	.ashade-mobile-menu-shown.ashade-albums-template--slider .ashade-albums-slider-wrap,
	.ashade-mobile-menu-shown main.ashade-content-wrap,
	.ashade-mobile-menu-shown .ashade-home-wrap,
	.ashade-mobile-menu-shown header#ashade-header {
		pointer-events: none;
		transform: translateX(-192px);
	}
	
	/* --- Contact Form --- */
	.ashade-contact-form .ashade-row.ashade-small-gap {
		flex-direction: column;
	}
	.ashade-contact-form .ashade-row.ashade-small-gap .ashade-col.col-4 {
		width: 100%;
		margin: 0;
	}
	
	/* --- Footer --- */
	.ashade-footer-inner {
		padding-left: 40px;
		padding-right: 40px;
	}
	
	/* --- Albums Listing --- */
	.ashade-albums-carousel .ashade-album-item__title h2 {
		font-size: 30px;
		line-height: 35px;
	}
	.ashade-albums-carousel .ashade-album-item__title h2 span {
		font-size: 12px;
		line-height: 14px;
	}
	.ashade-albums-carousel-wrap .ashade-album-item__title:before {
		top: 17px;
	}
	.ashade-slider-prev {
		left: 40px;
	}
	.ashade-slider-next {
		right: 40px;
	}
	
	/* --- Media Grid --- */
	.ashade-grid-2cols .ashade-grid-item,
	.ashade-grid-3cols .ashade-grid-item,
	.ashade-grid-4cols .ashade-grid-item,
	.ashade-grid-5cols .ashade-grid-item {
		width: calc(50% - 30px);
	}
	
	/* --- Elements --- */
	.ashade-testimonials-grid {
		margin: -20px -15px;
	}
	.ashade-testimonials-grid .ashade-testimonials-item {
		margin: 20px 15px;
		width: calc(50% - 30px);
	}
	
	/* --- Maintenance --- */
	.ashade-maintenance-wrap .ashade-contact-details {
		text-align: center;
		padding-top: 80px;
	}
	.ashade-maintenance-wrap .ashade-contact-details .ashade-contact-details__list {
		margin: 0 auto;
		text-align: left;
		display: inline-block;
	}
	.ashade-maintenance-wrap #ashade-contacts-wrap .col-8 {
		width: 100%;
	}
	.ashade-to-top-wrap {
		display: none;
	}
	.ashade-maintenance-wrap .ashade-to-top-wrap {
		display: flex;
		left: calc(100% - 91px);
	}
	.ashade-maintenance-wrap .ashade-content {
    	width: calc(100% - 352px);
    	margin: auto ;
	}
	
	.ashade-progress-item-wrap {
		padding: 0 20px;
	}
	.ashade-progress-counter {
		font-size: 20px;
		line-height: 25px;
		transform: translateX(3px);
	}
	
	/* --- Protected --- */
	.ashade-protected-form-wrap {
		padding: 0 40px;
	}
	
	/* --- 404 Page --- */
	body.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap {
		left: 40px;
	}
	body.ashade-layout--vertical .ashade-back-wrap {
		left: calc(100% - 86px);
	}
	
	/* --- Blog --- */
	aside#ashade-sidebar {
		padding-top: 80px;
	}

	/* --- Grid Filter --- */
	.ashade-filter-wrap {
		margin-bottom: 40px;
	}
	.ashade-filter-wrap a {
		margin: 0 10px;
	}
}

/* Mobile Phone Styles 
   ------------------- */
@media only screen and (max-width: 760px) {
	.ashade-maintenance-wrap .ashade-to-top-wrap.ashade-back-wrap {
		display: none;
	}
	.ashade-mobile-title-wrap {
		display: block;
		margin: 0 0 50px 0;
	}
	body .hide-on-desktop,
	body .hide-on-laptop,
	body .hide-on-tablet,
	body .hide-on-tablet-land,
	body .hide-on-tablet-port,
	body section.ashade-section.hide-on-desktop,
	body section.ashade-section.hide-on-laptop,
	body section.ashade-section.hide-on-tablet,
	body section.ashade-section.hide-on-tablet-land,
	body section.ashade-section.hide-on-tablet-port {
		display: block;
	}
	body .hide-on-phone,
	body section.ashade-section.hide-on-phone {
		display: none;
	}
	
	/* --- Grid --- */
	.ashade-row {
		display: flex;
		flex-direction: column;
		margin: 0;
	}
	.ashade-col {
		margin: 0 0 30px 0;
	}
	.ashade-col:last-child {
		margin: 0;
	}
	.ashade-row.ashade-small-gap,
	.ashade-grid.ashade-small-gap {
		margin: 0 0 0 0;
	}
	.ashade-row.ashade-small-gap .ashade-col:last-child,
	.ashade-grid.ashade-small-gap .ashade-col:last-child {
		margin: 0;
	}
	.ashade-row.ashade-small-gap .ashade-col {
		margin: 0 0 10px 0;
	}
	
	.ashade-col.col-12,
	.ashade-col.col-9, 
	.ashade-col.col-8, 
	.ashade-col.col-6, 
	.ashade-col.col-4, 
	.ashade-col.col-3, 
	.ashade-col.col-2,
	.ashade-small-gap.ashade-grid-1cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-2cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-3cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-4cols .ashade-grid-item,
	.ashade-small-gap.ashade-grid-5cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-1cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-2cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-3cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-4cols .ashade-grid-item,
	.ashade-no-gap.ashade-grid-5cols .ashade-grid-item,
	.ashade-contact-form .ashade-row.ashade-small-gap .ashade-col.col-4 {
		width: 100%;
	}
	.ashade-col:empty {
		display: none;
	}	
	.ashade-contact-form .ashade-row.ashade-small-gap .ashade-col.col-4 {
		margin: 0;
	}

	.ashade-smooth-scroll .ashade-content-scroll.is-centered {
		flex-direction: column;
	}
	
	/* --- Media Grid --- */
	.ashade-grid {
		margin: -15px 0;
		display: flex;
		flex-wrap: wrap;
	}
	.ashade-grid .ashade-grid-item {
		margin: 15px 0;
	}
	.ashade-grid-1cols .ashade-grid-item,
	.ashade-grid-2cols .ashade-grid-item,
	.ashade-grid-3cols .ashade-grid-item,
	.ashade-grid-4cols .ashade-grid-item,
	.ashade-grid-5cols .ashade-grid-item {
		width: 100%;
	}
	
	.ashade-gallery-bricks {
		margin: -5px;
	}
	.ashade-gallery-bricks .ashade-gallery-item {
		margin: 5px;
	}
	.ashade-gallery-bricks.is-1x2 .ashade-gallery-item {
		width: calc(50% - 10px);
	}
	.ashade-gallery-bricks.is-1x2 .ashade-gallery-item:nth-child(3n) {
		width: calc(100% - 10px);
	}
	.ashade-gallery-bricks.is-2x3 .ashade-gallery-item.is-large {
		width: calc(50% - 10px);
	}
	.ashade-gallery-bricks.is-2x3 .ashade-gallery-item.is-small {
		width: calc(33.33% - 10px);
	}

	/* --- Typography --- */
	.is-dropcap::first-letter,
	h1 {
		font-size: 40px;
		line-height: 45px;
		margin: 0 0 45px 0;
	}
	h1 span {
		font-size: 12px;
		line-height: 16px;
		margin: 0 0 0 0;
	}
	.ashade-mobile-title-wrap h1 > span {
		margin: 0 0 6px 0;
	}
	h2 {
		font-size: 35px;
		line-height: 40px;
		margin: 0 0 40px 0;
	}
	h3 {
		font-size: 30px;
		line-height: 35px;
		margin: 0 0 35px 0;
	}
	h3 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 1px 0;
	}
	.ashade-slider-prev,
	.ashade-slider-next,
	h4 {
		font-size: 24px;
		line-height: 29px;
		margin: 0 0 29px 0;
	}
	h4 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 0 0;
	}
	h5 {
		font-size: 20px;
		line-height: 25px;
		margin: 0 0 25px 0;
	}
	h5 span {
		font-size: 10px;
		line-height: 13px;
		margin: 0 0 0 0;
	}
	h6 {
		font-size: 18px;
		line-height: 23px;
		margin: 0 0 23px 0;
	}
	h6 span {
		font-size: 10px;
		line-height: 13px;
		margin: 0 0 0 0;
	}
	.is-dropcap::first-letter {
		margin: 4px 15px 0 0;
		font-size: 50px;
		line-height: 55px;
	}
	#ashade-coming-soon h2 {
		font-size: 35px;
		line-height: 40px;
	}
	#ashade-coming-soon span {
		font-size: 12px;
		line-height: 24px;
	}
	.ashade-service-item__content-inner h3 {
		font-size: 24px;
		line-height: 29px;
	}
	
	.ashade-mobile-title-wrap h1 {
		font-size: 30px;
		line-height: 35px;
		display: block;
		text-align: center;
	}
	.ashade-mobile-title-wrap h1 > span {
		transform: translate(0);
		text-align: center;
		justify-content: center;
	}
	
	/* --- Content --- */
	.ashade-content,
	body.ashade-layout--horizontal .ashade-content,
	body.ashade-layout--vertical .ashade-content {
		width: calc(100% - 40px);
	}
	.ashade-more-categories {
		max-width: calc(100% - 40px);
	}
	aside#ashade-aside {
		max-width: calc(100% - 40px);
	}
	aside#ashade-aside .ashade-aside-inner {
		width: 100%;
	}
	.ashade-aside-close {
		transform: translateX(calc(-100% - 20px)) rotate(-90deg);
	}
	.ashade-aside-content {
		padding: 40px 20px;
	}
	.ashade-widget {
		margin: 0 0 60px 0;
	}
	.ashade-page-title-wrap {
		display: none!important;
	}
	.ashade-content {
		margin: auto;
	}
	.ashade-content {
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.ashade-content {
	}
	#ashade-home-contacts p.ashade-intro {
		margin-bottom: 40px;
	}
	#ashade-home-works p.ashade-intro,
	section.ashade-section {
		margin-bottom: 80px;
	}
	p.ashade-intro {
		margin-bottom: 40px;
	}
	
	.ashade-contact-form__footer {
		flex-direction: column-reverse;
		justify-content: flex-end;
	}
	.ashade-contact-form__response span {
		display: block;
		padding-top: 10px;
	}
	body.ashade-layout--vertical .ashade-back-wrap:before {
		top: 17px;
	}
	
	/* --- Header --- */
	body:not(.has-header-padding) .ashade-header-holder,
	.ashade-header-holder {
		display: block;
	}
	header#ashade-header .ashade-header-inner {
		padding: 20px 20px;
	}
	nav.ashade-mobile-menu {
		width: 100%;
	}
	.ashade-menu-overlay {
		display: none;
	}
	
	.ashade-aside-shown.ashade-albums-template--ribbon .ashade-albums-carousel-wrap,
	.ashade-aside-shown.ashade-albums-template--slider .ashade-albums-slider-wrap,
	.ashade-aside-shown main.ashade-content-wrap,
	.ashade-aside-shown .ashade-home-wrap,
	.ashade-aside-shown header#ashade-header,
	.ashade-mobile-menu-shown.ashade-albums-template--ribbon .ashade-albums-carousel-wrap,
	.ashade-mobile-menu-shown.ashade-albums-template--slider .ashade-albums-slider-wrap,
	.ashade-mobile-menu-shown main.ashade-content-wrap,
	.ashade-mobile-menu-shown .ashade-home-wrap,
	.ashade-mobile-menu-shown header#ashade-header {
		pointer-events: none;
		transform: translateX(-50vw);
	}

	/* --- Footer --- */
	.page-template-page-maintenance footer#ashade-footer {
		position: static;
	}
	.ashade-footer-inner {
		flex-direction: column;
		align-items: center;
		padding: 15px 20px;
	}
	.ashade-footer-inner .ashade-footer__socials {
		margin-bottom: 15px;
	}
	
	.ashade-socials--left.ashade-copyright--left .ashade-footer-inner,
	.ashade-socials--left.ashade-copyright--center .ashade-footer-inner,
	.ashade-socials--left.ashade-copyright--right .ashade-footer-inner,
	.ashade-socials--center.ashade-copyright--left .ashade-footer-inner,
	.ashade-socials--center.ashade-copyright--center .ashade-footer-inner,
	.ashade-socials--center.ashade-copyright--right .ashade-footer-inner,
	.ashade-socials--right.ashade-copyright--left .ashade-footer-inner,
	.ashade-socials--right.ashade-copyright--center .ashade-footer-inner,
	.ashade-socials--right.ashade-copyright--right .ashade-footer-inner {
		flex-direction: column;
		justify-content: flex-start;
		align-items: stretch;
	}
	body footer .ashade-footer-inner .ashade-footer__socials {
		padding-bottom: 0px;
	}
	body footer .ashade-footer-inner .ashade-footer__socials,
	body footer .ashade-footer-inner .ashade-footer__copyright {
		text-align: center;
	}
	
	/* --- Albums --- */
	.ashade-filter-wrap > a {
		display: none;
	}
	.ashade-mobile-filter-wrap {
		display: block;
	}
	.ashade-albums-carousel-wrap .ashade-album-item__inner {
		margin-right: 20px;
	}
	.ashade-albums-carousel-wrap .ashade-album-item .ashade-button {
		bottom: 20px;
		right: 20px;
	}
	.ashade-albums-carousel-wrap .ashade-albums-carousel.is-medium .ashade-album-item a.ashade-button {
		height: 40px;
    	padding: 10px 20px;
    	font-size: 12px;
	}
	.ashade-albums-carousel-progress {
		display: none;
	}
	.ashade-albums-template--ribbon .ashade-albums-carousel-wrap .ashade-albums-carousel.is-vertical {
		width: calc(100% - 40px);
		margin: 0 auto;
	}
	.ashade-albums-template--ribbon .ashade-albums-carousel-wrap .ashade-albums-carousel.is-vertical div.ashade-album-item .ashade-album-item__inner {
		margin-bottom: 20px;
	}
	.ashade-albums-slider-wrap .ashade-album-item__explore, 
	body.ashade-layout--vertical .ashade-albums-slider-wrap .ashade-album-item__explore, 
	body.ashade-layout--vertical .ashade-back-wrap {
		margin: 0;
		left: calc(100% - 60px);
	}
	body.ashade-layout--horizontal .ashade-albums-slider-wrap .ashade-album-item__explore, 
	body.ashade-layout--horizontal .ashade-back-wrap {
		margin: 0;
	}
	.ashade-albums-slider-wrap .ashade-album-item__title h2 span {
		line-height: 18px;
		margin: 0;
	}
	.ashade-albums-slider .ashade-album-item__explore span, 
	.ashade-home-link span:first-child, 
	.ashade-back span:first-child {
		font-size: 10px;
		margin-bottom: 0;
	}
	.ashade-home-link span:first-child {
		margin-bottom: 1px;
	}
	.ashade-back-wrap.is-loaded .ashade-back:not(.is-to-top) span:first-child, 
	.has-to-top .ashade-back-wrap.is-loaded .ashade-back.is-to-top span:first-child {
		margin-bottom: 0;
	}
	.ashade-albums-slider-wrap .ashade-album-item__title.is-loaded h2 span {
		font-size: 12px;
		line-height: 15px;
		margin: 0 0 1px 0;
	}
	.ashade-albums-slider-wrap .ashade-album-item__title.is-loaded h2,
	.ashade-albums-slider .ashade-album-item__explore,
	.ashade-home-link span:last-child,
	.ashade-back span:last-child {
		font-size: 24px;
		line-height: 29px;
	}
	.ashade-back-wrap:before,
	.ashade-home-link-wrap:before {
		top: 18px;
	}
	body.ashade-layout--horizontal .ashade-back-wrap:before,
	.ashade-albums-slider-wrap .ashade-album-item__explore:before, 
	.ashade-albums-slider-wrap .ashade-album-item__title:before {
		top: 16px;
	}
	.ashade-slider-prev {
		left: 20px;
	}
	.ashade-slider-next {
		right: 20px;
	}
	.ashade-albums-template--slider .ashade-page-title-wrap {
		display: flex;
		left: 20px;
	}
	.ashade-albums-slider-wrap .ashade-album-item__title, 
	.ashade-page-title-wrap {
		left: 20px;
	}
	.ashade-page-title-wrap h1 {
		font-size: 40px;
		line-height: 45px;
	}
	.ashade-page-title-wrap h1 span {
		font-size: 12px;
		line-height: 18px;
	}
	.ashade-albums-template--slider .ashade-page-title-wrap:before {
		top: 20px;	
	}
	.ashade-albums-template--slider .ashade-page-title-wrap h1 {
		font-size: 30px;
		line-height: 35px;
	}
	.ashade-mobile-title-wrap:before {
		top: 18px;
	}
	
	/* --- Home Template --- */
	.ashade-home-template .ashade-content {
		padding-top: 50px;
	}
	.ashade-content-shown footer#ashade-footer {
		opacity: 0;
		pointer-events: none;
	}
	#ashade-home-works .ashade-grid-2cols .ashade-grid-item, 
	#ashade-home-works .ashade-grid-3cols .ashade-grid-item, 
	#ashade-home-works .ashade-grid-4cols .ashade-grid-item,
	#ashade-home-works .ashade-grid-5cols .ashade-grid-item {
		width: 100%;
	}
	body.ashade-home-template .ashade-content {
		margin: auto auto auto 20px;
		width: calc(100% - 95px);
	}
	#ashade-home-works {
		padding-bottom: 0;
	}
	.ashade-home-link--works.ashade-home-link-wrap {
		left: calc(25% - 21px);
	}
	.ashade-home-link--contacts.ashade-home-link-wrap {
		left: calc(75% - 41px);
	}
	.ashade-home-link-wrap {
		padding-left: 130px;
	}
	
	body.ashade-layout--horizontal .ashade-back-wrap.ashade-home-return:before,
	body.ashade-layout--vertical .ashade-back-wrap.ashade-home-return:before {
		transition: opacity 0.3s;
		opacity: 0;
	}
	body.ashade-layout--horizontal.ashade-content-shown .ashade-back-wrap.ashade-home-return:before,
	body.ashade-layout--vertical.ashade-content-shown .ashade-back-wrap.ashade-home-return:before {
		opacity: 1;
	}
	
	/* --- Services --- */
	.ashade-services-block {
		padding: 0 0 40px 0;
		margin: -40px 0 0 0;
	}
	.ashade-service-item {
		flex-direction: column;
	}
	.ashade-service-item:nth-child(even ) {
		flex-direction: column;
	}
	.ashade-service-item .ashade-service-item__content,
	.ashade-service-item .ashade-service-item__image {
		width: calc(100% - 40px);
	}
	.ashade-service-item .ashade-service-item__image {
		margin: 0 auto 0 0;
	}
	.ashade-service-item .ashade-service-item__content {
		margin: -40px 0 0 auto;
	}
	.ashade-service-item:nth-child(even ) .ashade-service-item__content {
		margin: -40px auto 0 0;
	}
	.ashade-service-item:nth-child(even ) .ashade-service-item__image {
		margin: 0 0 0 auto;
	}
	.ashade-service-item__content-inner {
		padding: 30px 20px 24px 20px;
	}
	
	/* --- Testimonials Grid --- */
	.ashade-testimonials-grid {
		margin: -20px 0;
	}
	.ashade-testimonials-grid .ashade-testimonials-item {
		margin: 20px 0;
		width: 100%;
	}
	
	/* --- Maintenance --- */
	.ashade-maintenance-wrap .ashade-contact-details {
		text-align: center;
		padding-top: 30px;
	}
	.ashade-maintenance-wrap .ashade-to-top-wrap {
		display: none;
	}
	.ashade-maintenance-wrap .ashade-content {
    	width: 100%;
    	margin: auto ;
	}

	.ashade-albums-carousel-wrap .is-inview .ashade-album-item__title h2 span,
	.ashade-page-title-wrap.is-loaded h1 > span {
		transform: translateX(-30px);
	}
	.ashade-albums-carousel-wrap .is-inview .ashade-album-item__title {
		left: 20px;
	}
	.ashade-albums-carousel-wrap .is-inview .ashade-album-item__title h2 {
		padding-left: 30px;
	}
	.ashade-albums-carousel-wrap .is-vertical .ashade-album-item__title:before {
		top: 16px;
	}
	.ashade-albums-carousel.is-medium .ashade-album-item__title h2,
	.ashade-albums-carousel .ashade-album-item__title h2 {
		font-size: 20px;
		line-height: 24px;
	}
	.ashade-albums-carousel.is-medium .ashade-album-item__title h2 span {
		font-size: 10px;
		line-height: 15px;
	}
	.ashade-slider-prev,
	.ashade-slider-next {
		margin: 0;
		bottom: 70px;
	}
	
	.ashade-testimonials-carousel .ashade-testimonials-item__content {
		font-size: 16px;
		line-height: 28px;
	}
	.ashade-progress-item-wrap {
		max-width: 180px;
		margin: 0 auto;
	}
	.ashade-service-card__content {
		padding: 40px 20px 23px 20px;
		margin: -20px 0 0 20px;
	}
	.ashade-service-card__head img {
		width: 80px;
	}
	.ashade-service-card .ashade-service-card__label h4 {
		font-size: 18px;
		line-height: 23px;
	}
	.ashade-service-card .ashade-service-card__label h4 span {
		font-size: 12px;
		line-height: 15px;
	}
	.ashade-service-card .ashade-service-card__label h4 {
		margin: 7px 0 0 0;
	}
	
	/* --- Protected --- */
	.ashade-protected-form-wrap {
		padding: 0 20px;
	}
	.ashade-protected-text {
		padding: 50px 0 60px 0;
	}
	.ashade-protected-text .ashade-protected-input-wrap {
		margin: 0 0 0 0;
		width: 100%;
	}
	.ashade-protected-form-inner {
		flex-wrap: wrap;
	}
	.ashade-protected-text .ashade-protected-submit-wrap {
		text-align: center;
		width: 100%;
	}
	.ashade-protected-text .ashade-protected-submit-wrap input {
		margin: 0 auto;
	}
	body.ashade-layout--vertical .ashade-protected-inner .ashade-back-wrap {
		position: relative;
		left: auto;
		top: auto!important;
		transform: none;
		width: 100vw;
	}
	
	/* --- 404 --- */
	body.ashade-layout--vertical .ashade-404-inner .ashade-back-wrap.ashade-404-return-wrap {
		left: 20px;
	}
	.ashade-404-text h1 {
		font-size: 80px;
		line-height: 85px;
	}
	.ashade-404-text {
		font-size: 16px;
		line-height: 28px;
	}
	.ashade-404-text {
		padding: 50px 0 60px 0;
	}
	
	/* --- Blog Styles --- */
	.ashade-post-preview.sticky .ashade-preview-header {
		padding-right: 60px;
	}
	.ashade-post-preview.sticky .ashade-preview-header:before {
		width: 40px;
		height: 40px;
	}
	.ashade-post-preview.sticky .ashade-preview-header:after {
		top: 12px;
		right: 11px;
		width: 16px;
		height: 16px;
	}
	
	.shadowcore-blog-listing .ashade-post-preview, 
	.ashade-search-listing .ashade-post-preview, 
	.ashade-blog-listing .ashade-post-preview {
		margin: 60px 0 0 0;
	}
	aside#ashade-sidebar {
		padding-top: 60px;
	}
	.post-nav-links, 
	nav.pagination .nav-links {
		margin: 0 -5px;
		padding-top: 60px;
	}
	.post-nav-links span, 
	.post-nav-links a, 
	nav.pagination .nav-links a, 
	nav.pagination .nav-links span {
		margin: 0 5px;
		width: 40px;
		height: 40px;
	}
	nav.pagination .nav-links a svg,
	.post-nav-links a svg {
		transform: scale(0.75);
	}
	nav.pagination .nav-links > a:before, 
	nav.pagination .nav-links > span:before {
		display: none;
	}
	.ashade-post-navigation-wrap .ashade-post-nav-icon {
		display: none;
	}
	.ashade-post-navigation-wrap h6 {
		font-size: 16px;
	}
	.ashade-post-featured-image {
		margin-bottom: 60px;
	}
	body .ashade-post__tags {
		margin: 50px 0 0 -10px;
	}
	.ashade-post-navigation-wrap {
		margin: 60px 0 0 0;
		position: relative;
	}
	#ashade-comments {
		padding-top: 60px;
		margin: 60px 0 0 0;
	}
	.ashade-post-navigation-wrap.has-prev.has-next:before {
		content: '';
		width: 1px;
		height: 100%;
		position: absolute;
		left: 50%;
		top: 0;
		background: rgba(255,255,255,0.15);
	}
	.ashade-post-navigation-wrap .ashade-prev-post-link {
		padding-right: 20px;
	}
	.ashade-post-navigation-wrap .ashade-next-post-link {
		padding-left: 20px;
	}
	
	/* --- Comment Form --- */
	.ashade-comment-form .comment-form-author, 
	.ashade-comment-form .comment-form-email {
		width: 100%;
		margin: 0;
		padding: 0;
	}
}
/* Old Mobile Phone Styles */
@media only screen and (max-width: 340px) {
	.ashade-service-card .ashade-service-card__label h4 {
		font-size: 16px;
		line-height: 21px;
	}
	.ashade-service-card .ashade-service-card__label h4 span {
		font-size: 10px;
		line-height: 13px;
	}
	.ashade-service-card .ashade-service-card__label h4 {
		margin: 12px 0 0 0;
	}
	.ashade-service-card__content {
		margin-top: -17px;
	}
}/*! PhotoSwipe main CSS by Dmitry Semenov | photoswipe.com | MIT license */
/*
	Styles for basic PhotoSwipe functionality (sliding area, open/close transitions)
*/
/* pswp = photoswipe */
.pswp {
  display: none;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  overflow: hidden;
  -ms-touch-action: none;
  touch-action: none;
  z-index: 1500;
  -webkit-text-size-adjust: 100%;
  /* create separate layer, to avoid paint on window.onscroll in webkit/blink */
  -webkit-backface-visibility: hidden;
  outline: none; }
  .pswp * {
    -webkit-box-sizing: border-box;
            box-sizing: border-box; }
  .pswp img {
    max-width: none; }

/* style is added when JS option showHideOpacity is set to true */
.pswp--animate_opacity {
  /* 0.001, because opacity:0 doesn't trigger Paint action, which causes lag at start of transition */
  opacity: 0.001;
  will-change: opacity;
  /* for open/close transition */
  -webkit-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
          transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp--open {
  display: block; }

.pswp--zoom-allowed .pswp__img {
  /* autoprefixer: off */
  cursor: -webkit-zoom-in;
  cursor: -moz-zoom-in;
  cursor: zoom-in; }

.pswp--zoomed-in .pswp__img {
  /* autoprefixer: off */
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: grab; }

.pswp--dragging .pswp__img {
  /* autoprefixer: off */
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing; }

/*
	Background is added as a separate element.
	As animating opacity is much faster than animating rgba() background-color.
*/
.pswp__bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: #000;
  opacity: 0;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
  -webkit-backface-visibility: hidden;
  will-change: opacity; }

.pswp__scroll-wrap {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden; }

.pswp__container,
.pswp__zoom-wrap {
  -ms-touch-action: none;
  touch-action: none;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0; }

/* Prevent selection and tap highlights */
.pswp__container,
.pswp__img {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
      user-select: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none; }

.pswp__zoom-wrap {
  position: absolute;
  width: 100%;
  -webkit-transform-origin: left top;
  -ms-transform-origin: left top;
  transform-origin: left top;
  /* for open/close transition */
  -webkit-transition: -webkit-transform 333ms cubic-bezier(0.4, 0, 0.22, 1);
          transition: transform 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp__bg {
  will-change: opacity;
  /* for open/close transition */
  -webkit-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
          transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1); }

.pswp--animated-in .pswp__bg,
.pswp--animated-in .pswp__zoom-wrap {
  -webkit-transition: none;
  transition: none; }

.pswp__container,
.pswp__zoom-wrap {
  -webkit-backface-visibility: hidden; }

.pswp__item {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  overflow: hidden; }

.pswp__img {
  position: absolute;
  width: auto;
  height: auto;
  top: 0;
  left: 0; }

/*
	stretched thumbnail or div placeholder element (see below)
	style is added to avoid flickering in webkit/blink when layers overlap
*/
.pswp__img--placeholder {
  -webkit-backface-visibility: hidden; }

/*
	div element that matches size of large image
	large image loads on top of it
*/
.pswp__img--placeholder--blank {
  background: #222; }

.pswp--ie .pswp__img {
  width: 100% !important;
  height: auto !important;
  left: 0;
  top: 0; }

/*
	Error message appears when image is not loaded
	(JS option errorMsg controls markup)
*/
.pswp__error-msg {
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
  text-align: center;
  font-size: 14px;
  line-height: 16px;
  margin-top: -8px;
  color: #CCC; }

.pswp__error-msg a {
  color: #CCC;
  text-decoration: underline; }
	/*! PhotoSwipe Default UI CSS by Dmitry Semenov | photoswipe.com | MIT license */
/*

	Contents:

	1. Buttons
	2. Share modal and links
	3. Index indicator ("1 of X" counter)
	4. Caption
	5. Loading indicator
	6. Additional styles (root element, top bar, idle state, hidden state, etc.)

*/
/*
	
	1. Buttons

 */
/* <button> css reset */
.pswp__button {
	width: 44px;
	height: 44px;
	position: relative;
	background: none;
	cursor: pointer;
	overflow: visible;
	-webkit-appearance: none;
	display: block;
	border: 0;
	padding: 0;
	margin: 0;
	float: right;
	opacity: 0.75;
	-webkit-transition: opacity 0.2s;
	transition: opacity 0.2s;
	-webkit-box-shadow: none;
	box-shadow: none;
}
.pswp__button svg {
	pointer-events: none;
}
.pswp__button:focus,
.pswp__button:hover {
	opacity: 1;
}

.pswp__button:active {
	outline: none;
	opacity: 0.9;
}

.pswp__button::-moz-focus-inner {
	padding: 0;
	border: 0;
}

/* pswp__ui--over-close class it added when mouse is over element that should close gallery */
.pswp__ui--over-close .pswp__button--close {
	opacity: 1;
}

/* no arrows on touch screens */
.pswp--touch .pswp__button--arrow--left,
.pswp--touch .pswp__button--arrow--right {
	visibility: hidden;
}

/*
	Arrow buttons hit area
	(icon is added to :before pseudo-element)
*/
.pswp__button--arrow--left,
.pswp__button--arrow--right {
	background: none;
	top: 50%;
	margin-top: -50px;
	width: 70px;
	height: 100px;
	position: absolute;
}

.pswp__button--arrow--left {
	left: 10px;
}

.pswp__button--arrow--right {
	right: 10px;
}

.pswp__button--arrow--left:before {
	left: 15px;
	background-position: 0 0;
}

.pswp__button--arrow--right:before {
	right: 15px;
	background-position: -24px 0;
}
.pswp__scroll-wrap {
	cursor: grab;
}

/*

	2. Share modal/popup and links

 */
.pswp__counter,
.pswp__share-modal {
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
}

.pswp__share-modal {
	display: block;
	background: rgba(0, 0, 0, 0.5);
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	padding: 10px;
	position: absolute;
	z-index: 1600;
	opacity: 0;
	-webkit-transition: opacity 0.25s ease-out;
	transition: opacity 0.25s ease-out;
	-webkit-backface-visibility: hidden;
	will-change: opacity;
}

.pswp__share-modal--hidden {
	display: none;
}

.pswp__share-tooltip {
	z-index: 1620;
	position: absolute;
	background: #FFF;
	top: 56px;
	border-radius: 2px;
	display: block;
	width: auto;
	right: 44px;
	-webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.25);
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.25);
	-webkit-transform: translateY(6px);
	-ms-transform: translateY(6px);
	transform: translateY(6px);
	-webkit-transition: -webkit-transform 0.25s;
	transition: transform 0.25s;
	-webkit-backface-visibility: hidden;
	will-change: transform;
}

.pswp__share-tooltip a {
	display: block;
	padding: 8px 12px;
	color: #000;
	text-decoration: none;
	font-size: 14px;
	line-height: 18px;
}

.pswp__share-tooltip a:hover {
	text-decoration: none;
	color: #000;
}

.pswp__share-tooltip a:first-child {
	/* round corners on the first/last list item */
	border-radius: 2px 2px 0 0;
}

.pswp__share-tooltip a:last-child {
	border-radius: 0 0 2px 2px;
}

.pswp__share-modal--fade-in {
	opacity: 1;
}

.pswp__share-modal--fade-in .pswp__share-tooltip {
	-webkit-transform: translateY(0);
	-ms-transform: translateY(0);
	transform: translateY(0);
}

/* increase size of share links on touch devices */
.pswp--touch .pswp__share-tooltip a {
	padding: 16px 12px;
}

a.pswp__share--facebook:before {
	content: '';
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: -12px;
	right: 15px;
	border: 6px solid transparent;
	border-bottom-color: #FFF;
	-webkit-pointer-events: none;
	-moz-pointer-events: none;
	pointer-events: none;
}

a.pswp__share--facebook:hover {
	background: #3E5C9A;
	color: #FFF;
}

a.pswp__share--facebook:hover:before {
	border-bottom-color: #3E5C9A;
}

a.pswp__share--twitter:hover {
	background: #55ACEE;
	color: #FFF;
}

a.pswp__share--pinterest:hover {
	background: #CCC;
	color: #CE272D;
}

a.pswp__share--download:hover {
	background: #DDD;
}

/*

	3. Index indicator ("1 of X" counter)

 */
.pswp__counter {
	position: absolute;
	left: 0;
	top: 0;
	height: 44px;
	font-size: 13px;
	line-height: 44px;
	color: #FFF;
	opacity: 0.75;
	padding: 0 10px;
}

/*
	
	4. Caption

 */
.pswp__caption {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	min-height: 44px;
}

.pswp__caption small {
	font-size: 11px;
	color: #BBB;
}

.pswp__caption__center {
	text-align: left;
	max-width: 420px;
	margin: 0 auto;
	font-size: 13px;
	padding: 10px;
	line-height: 20px;
	color: #CCC;
}

.pswp__caption--empty {
	display: none;
}

/* Fake caption element, used to calculate height of next/prev image */
.pswp__caption--fake {
	visibility: hidden;
}

/*

	5. Loading indicator (preloader)

	You can play with it here - http://codepen.io/dimsemenov/pen/yyBWoR

 */
.pswp__preloader {
	width: 44px;
	height: 44px;
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -22px;
	opacity: 0;
	-webkit-transition: opacity 0.25s ease-out;
	transition: opacity 0.25s ease-out;
	will-change: opacity;
	direction: ltr;
}

.pswp__preloader__icn {
	width: 20px;
	height: 20px;
	margin: 12px;
}

.pswp__preloader--active {
	opacity: 1;
}

.pswp__preloader--active .pswp__preloader__icn {
	/* We use .gif in browsers that don't support CSS animation */
	background: url(//vervedesign.jp/wp-content/themes/ashade/assets/css/lib/default-skin/preloader.gif) 0 0 no-repeat;
}

.pswp--css_animation .pswp__preloader--active {
	opacity: 1;
}

.pswp--css_animation .pswp__preloader--active .pswp__preloader__icn {
	-webkit-animation: clockwise 500ms linear infinite;
	animation: clockwise 500ms linear infinite;
}

.pswp--css_animation .pswp__preloader--active .pswp__preloader__donut {
	-webkit-animation: donut-rotate 1000ms cubic-bezier(0.4, 0, 0.22, 1) infinite;
	animation: donut-rotate 1000ms cubic-bezier(0.4, 0, 0.22, 1) infinite;
}

.pswp--css_animation .pswp__preloader__icn {
	background: none;
	opacity: 0.75;
	width: 14px;
	height: 14px;
	position: absolute;
	left: 15px;
	top: 15px;
	margin: 0;
}

.pswp--css_animation .pswp__preloader__cut {
	/* 
			The idea of animating inner circle is based on Polymer ("material") loading indicator 
			 by Keanu Lee https://blog.keanulee.com/2014/10/20/the-tale-of-three-spinners.html
		*/
	position: relative;
	width: 7px;
	height: 14px;
	overflow: hidden;
}

.pswp--css_animation .pswp__preloader__donut {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 14px;
	height: 14px;
	border: 2px solid #FFF;
	border-radius: 50%;
	border-left-color: transparent;
	border-bottom-color: transparent;
	position: absolute;
	top: 0;
	left: 0;
	background: none;
	margin: 0;
}

@media screen and (max-width: 1024px) {
	.pswp__preloader {
		position: relative;
		left: auto;
		top: auto;
		margin: 0;
		float: right;
	}
}

@-webkit-keyframes clockwise {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@keyframes clockwise {
	0% {
		-webkit-transform: rotate(0deg);
		transform: rotate(0deg);
	}

	100% {
		-webkit-transform: rotate(360deg);
		transform: rotate(360deg);
	}
}

@-webkit-keyframes donut-rotate {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}

	50% {
		-webkit-transform: rotate(-140deg);
		transform: rotate(-140deg);
	}

	100% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}
}

@keyframes donut-rotate {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}

	50% {
		-webkit-transform: rotate(-140deg);
		transform: rotate(-140deg);
	}

	100% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}
}

/*
	
	6. Additional styles

 */
/* root element of UI */
.pswp__ui {
	-webkit-font-smoothing: antialiased;
	visibility: visible;
	opacity: 1;
	z-index: 1550;
}

/* top black bar with buttons and "1 of X" indicator */
.pswp__top-bar {
	position: absolute;
	left: 0;
	top: 0;
	height: 44px;
	width: 100%;
}

.pswp__caption,
.pswp__top-bar,
.pswp--has_mouse .pswp__button--arrow--left,
.pswp--has_mouse .pswp__button--arrow--right {
	-webkit-backface-visibility: hidden;
	will-change: opacity;
	-webkit-transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
	transition: opacity 333ms cubic-bezier(0.4, 0, 0.22, 1);
}

/* pswp--has_mouse class is added only when two subsequent mousemove events occur */
.pswp--has_mouse .pswp__button--arrow--left,
.pswp--has_mouse .pswp__button--arrow--right {
	visibility: visible;
}

.pswp__top-bar {
	background-color: rgba(0, 0, 0, 0.15);
}
.pswp__caption {
	background-color: rgba(0, 0, 0, 0.25);
}

/* pswp__ui--fit class is added when main image "fits" between top bar and bottom bar (caption) */
.pswp__ui--fit .pswp__top-bar,
.pswp__ui--fit .pswp__caption {
	background-color: rgba(0, 0, 0, 0.3);
}

/* pswp__ui--idle class is added when mouse isn't moving for several seconds (JS option timeToIdle) */
.pswp__ui--idle .pswp__top-bar {
	opacity: 0;
}

.pswp__ui--idle .pswp__button--arrow--left,
.pswp__ui--idle .pswp__button--arrow--right {
	opacity: 0;
}

/*
	pswp__ui--hidden class is added when controls are hidden
	e.g. when user taps to toggle visibility of controls
*/
.pswp__ui--hidden .pswp__top-bar,
.pswp__ui--hidden .pswp__caption,
.pswp__ui--hidden .pswp__button--arrow--left,
.pswp__ui--hidden .pswp__button--arrow--right {
	/* Force paint & create composition layer for controls. */
	opacity: 0.001;
}

/* pswp__ui--one-slide class is added when there is just one item in gallery */
.pswp__ui--one-slide .pswp__button--arrow--left,
.pswp__ui--one-slide .pswp__button--arrow--right,
.pswp__ui--one-slide .pswp__counter {
	display: none;
}

.pswp__element--disabled {
	display: none !important;
}

.pswp--minimal--dark .pswp__top-bar {
	background: none;
}

/* New Styles */
.pswp-video-wrapper,
img.pswp__img {
	border: 5px solid #000;
	box-shadow: 0 0 15px hsla(0, 0%, 0%, .8);
}

.pswp__ui--idle .pswp__top-bar {
	opacity: 1;
}

.pswp__counter {
	display: none;
}

.pswp__top-bar button.pswp__button--close {
	display: inline-block !important;
}

.pswp__button--arrow--left, 
.pswp__button--arrow--right {
	opacity: 1!important;
	width: 50px;
	height: 60px;
}
.pswp__top-bar button.pswp__button.pswp__button--close,
.pswp__button--arrow--left,
.pswp__button--arrow--right {
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.pswp__top-bar button.pswp__button.pswp__button--close svg,
.pswp__button--arrow--left svg, 
.pswp__button--arrow--right svg {
	display: block;
	max-width: 100%;
	height: auto;
	transform: scale(1);
	transition: transform 0.3s;
}
.pswp__top-bar button.pswp__button.pswp__button--close:hover svg,
.pswp__button--arrow--left:hover svg,
.pswp__button--arrow--right:hover svg {
	transform: scale(1.3);
}
.pswp__top-bar button.pswp__button.pswp__button--close svg path,
.pswp__button--arrow--left svg path, 
.pswp__button--arrow--right svg path {
	fill: rgba(255, 255, 255, 0.5);
	transition: fill 0.3s;
}
.pswp__top-bar button.pswp__button.pswp__button--close:hover svg path,
.pswp__button--arrow--left:hover svg path, 
.pswp__button--arrow--right:hover svg path {
	fill: rgba(255, 255, 255, 1);
}
.pswp__ui--fit .pswp__top-bar {
	background: none;
	box-sizing: border-box;
	padding: 12px 0 0 10px;
}
.admin-bar .pswp__ui--fit .pswp__top-bar {
	background: none;
	box-sizing: border-box;
	padding: 44px 0 0 10px;
}
.pswp__ui--fit .pswp__top-bar button.pswp__button {
	float: right;
	width: 50px;
	height: 32px;
	opacity: 1!important;
	outline: none;
	margin-right: 5px;
}
.pswp_item_wrapper {
	position: relative;
}
.pswp__caption {
	display: flex;
	flex-direction: row;
	align-items: flex-end;
	background: transparent!important;
}
.pswp__caption .pswp__caption__center:empty {
	display: none;
}
.pswp__caption .pswp__caption__center {
	text-shadow: 0 1px #000;
	color: #fff;
	text-align: center;
    font-size: 12px;
    line-height: 150%;
    word-wrap: break-word;
    padding: 13px 50px;
    border-radius: 3px 3px 0 0;
    margin: 0 auto;
    max-width: 100%;
	background: rgba(0,0,0,0.65);
}

.pswp-video-wrapper {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
.pswp-video-wrapper iframe {
	display: block;
	width: 100%;
	height: 100%;
}

.pswp__item {
	pointer-events: none;
}