
/*------------------------------------------------------------------
    Header
-------------------------------------------------------------------*/

	@media (min-width: 1025px) {

		.concept42 .classic-menu .nav-height {
			background-color: transparent;
		}

		.concept42 .classic-menu #c42-nav-wrapper {
			position: absolute;
			top: 50%;
			left: 50%;
			width: auto;
			height: auto;
			padding: 10px;
			background-color: rgba(128, 128, 128, 0.35);
			border-radius: 3px;
			-webkit-backdrop-filter: blur(7px);
			backdrop-filter: blur(7px);
			transform: translate(-50%, -50%);
		}

	}

	.concept42 #header-button .button-icon i {
		background-color: var(--primary-color);
		color: var(--color-black);
		filter: none;
	}

	.concept42 #header-button .button-icon i::before {
		filter: none;
	}



/*------------------------------------------------------------------
    Footer
-------------------------------------------------------------------*/

	.concept42 #c42-footer:not(.absolute) {
		overflow: visible;
		color: var(--color-white);
		background-color: var(--fullscreen-menu-bg-color);
	}

	.concept42 #c42-footer:not(.absolute)::before {
		content: "";
		position: absolute;
		top: -20px;
		left: 0;
		width: calc(50% - 1px);
		height: 20px;
		background-color: var(--fullscreen-menu-bg-color);
		border-top-right-radius: 10px;
	}

	.concept42 #c42-footer:not(.absolute)::after {
		content: "";
		position: absolute;
		top: -20px;
		right: 0;
		width: calc(50% - 1px);
		height: 20px;
		background-color: var(--fullscreen-menu-bg-color);
		border-top-left-radius: 10px;
	}

	@media only screen and (max-width: 1024px) {

		.concept42 #c42-footer:not(.absolute) {
			overflow: hidden;
		}

		.concept42 .footer-nav-lists {
			grid-template-rows: repeat(5, auto);
		}

	}

	@media only screen and (max-width: 767px) {

		.concept42 #c42-footer:not(.absolute) .c42-footer-left {
			right: 0;
			left: auto;
			justify-content: flex-end;
		}

		.concept42 #c42-footer:not(.absolute) #backtotop {
			bottom: -6px;
			left: 16px;
		}

		.concept42 #c42-footer:not(.absolute) .c42-footer-center {
			justify-content: flex-start;
		}

		.concept42 #c42-footer:not(.absolute) .c42-footer-right {
			justify-content: flex-start;
		}

		.concept42 #c42-footer:not(.absolute) .socials-wrap .socials {
			-webkit-transform: translateX(-14px);
			transform: translateX(-14px);
		}

	}



/*------------------------------------------------------------------
    Hero Section
-------------------------------------------------------------------*/

	.concept42 .has-media #hero-caption {
		justify-content: flex-end;
	}

	.concept42 #hero-caption.text-align-default-desktop .inner {
		width: 100%;
	}

	.concept42 #hero-caption.text-align-default-desktop .hero-subtitle {
		width: 100%;
		box-sizing: border-box;
		padding-left: calc(66.6667% - (1 * var(--gap)) / 3 + var(--gap));
	}

	.concept42 #hero-caption.error-caption .hero-title {
		font-size: var(--bt-font-size);
		line-height: var(--bt-line-height);
		font-weight: var(--bt-font-weight);
		letter-spacing: var(--bt-letter-spacing);
		column-gap: 0;
	}

	.concept42 #hero-caption.error-caption .hero-title .word-wrapper span {
		text-shadow: 0 1.05em 0 currentColor;
	}

	.concept42 .has-border {
		--segment: calc(
			(100% - (var(--horizontal-gutter) * 2) - (var(--gap) * 2)) / 3
		);
		mask-image: linear-gradient(
			to right,
			transparent 0,
			transparent var(--horizontal-gutter),
			black var(--horizontal-gutter),
			black calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent 100%
		);
	}

	.concept42 .has-border::before {
		top: 0;
		bottom: auto;
		transform-origin: left;
	}

	.concept42 .has-border::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 2px;
		background-image:
			linear-gradient(to top, var(--color-black) 0%, var(--color-black) 100%),
			linear-gradient(to right, transparent, transparent),
			linear-gradient(to top, transparent, transparent);
		background-position: -100% 50%, 50% 0, 0 50%;
		background-repeat: no-repeat;
		background-size: 50% 2px, 2px 100%, 100% 2px;
		opacity: 1;
	}

	.concept42 .light-content .has-border::after {
		background-image:
			linear-gradient(to top, var(--color-white) 0%, var(--color-white) 100%),
			linear-gradient(to right, transparent, transparent),
			linear-gradient(to top, transparent, transparent);
	}

	.concept42 .has-border.visible::after {
		background-position: 100% 0%, 50% 0, 0 50%;
		background-size: 0 2px, 2px 100%, 100% 2px;
		transition: transform 0.5s ease-out 0s, background-size 1.5s cubic-bezier(.69, 0, 0, 1) 0.45s, background-position 0.6s cubic-bezier(.6, 0, .05, 1) 0.45s;
	}

	.concept42 .hero-footer-left {
		display: flex;
		justify-content: flex-start;
		width: calc(33.3333% - (2 * var(--gap)) / 3);
	}

	.concept42 .hero-footer-center {
		display: flex;
		justify-content: flex-start;
		width: calc(33.3333% - (2 * var(--gap)) / 3);
	}

	.concept42 .hero-footer-right {
		display: flex;
		justify-content: flex-end;
		width: calc(33.3333% - (2 * var(--gap)) / 3);
	}

	.concept42 .hero-footer-left #back-home .text-wrap {
		white-space: nowrap;
	}

	.concept42 .hero-footer-left #back-home .button-text {
		display: block;
	}

	/* Responsive */

	@media only screen and (max-width: 1024px) {

		.concept42 #hero-caption.text-align-default-desktop .hero-subtitle {
			margin-top: 40px;
			padding-left: calc(33.3333% + var(--gap) / 3);
		}

	}

	@media only screen and (max-width: 767px) {

		.concept42 #hero-caption.text-align-default-desktop .hero-subtitle {
			margin-top: 20px;
			padding-left: 0;
		}

	}



/*------------------------------------------------------------------
    Page Nav Section
-------------------------------------------------------------------*/

	.concept42 .nav-intro-wrapper {
		position: absolute;
		z-index: 1000;
		display: flex;
		flex-direction: column;
		gap: calc(var(--gap) / 2);
		width: 100%;
		height: auto;
		box-sizing: border-box;
		padding-top: calc(var(--header-height) - var(--gap) * 2);
		padding-left: var(--horizontal-gutter);
		padding-right: var(--horizontal-gutter);
	}

	.concept42 .nav-intro-wrapper .nav-intro-text {
		display: flex;
		justify-content: flex-start;
		width: 100%;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-text {
		position: relative;
		display: flex;
		align-items: stretch;
		justify-content: flex-start;
		width: 100%;
		column-gap: 0.2em;
		flex-shrink: 0;
	}

	.concept42 .nav-intro-wrapper.text-align-center .nav-intro-text .span-text {
		justify-content: center;
	}

	.concept42 .nav-intro-wrapper.text-align-right .nav-intro-text .span-text {
		justify-content: flex-end;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-word {
		overflow: hidden;
		justify-content: center;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-word:first-child {
		justify-content: flex-start;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-word:last-child {
		justify-content: flex-end;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-word span {
		position: relative;
		display: block;
	}

	.concept42 .nav-intro-wrapper .nav-intro-text .span-word span::before {
		content: attr(data-hover);
		position: absolute;
		top: 0;
		left: 0;
		width: auto;
		-webkit-transform: translateY(100%);
		transform: translateY(100%);
	}

	.concept42 .next-hero-subtitle {
		opacity: 1;
	}



/*------------------------------------------------------------------
    Showcase Slider Parallax
-------------------------------------------------------------------*/

	.concept42 .c42-slider-wrapper .c42-slider-caption {
		justify-content: flex-start;
	}

	.concept42 .c42-slider-wrapper .c42-slider-caption .item-caption {
		position: absolute;
		display: flex;
		align-items: center;
		justify-content: space-between;
		width: 100%;
		height: auto;
		text-align: left;
	}

	.concept42 .c42-slider-wrapper .c42-slider-caption .item-title {
		left: -0.06em;
	}

	.concept42 .c42-slider-wrapper .c42-slider-caption .item-role {
		text-align: right;
	}

	.concept42 .c42-slider-wrapper .c42-slider-caption .item-cat > span {
		display: block;
	}

	/* Slider Pagination Bullets */

	.concept42 .c42-slider-footer {
		overflow: visible;
	}

	.concept42 .showcase-slider-parallax .c42-slider-pagination {
		position: absolute;
		top: 0;
		left: 0;
		z-index: 20;
		display: flex;
		align-items: center;
		justify-content: flex-start;
		width: 100%;
		height: auto;
		box-sizing: border-box;
		padding-left: var(--horizontal-gutter);
		padding-right: var(--horizontal-gutter);
		gap: var(--gap);
		counter-reset: slide;
		pointer-events: none;
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet {
		position: relative;
		display: inline-flex;
		align-items: flex-start;
		justify-content: flex-start;
		width: 100%;
		height: auto;
		padding-bottom: 40px;
		margin: 0;
		opacity: 1;
		cursor: pointer;
		pointer-events: none;
		-webkit-transition: opacity 0.2s ease-in-out;
		transition: opacity 0.2s ease-in-out;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet::after {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		height: 1px;
		opacity: 0.2;
		background-color: currentColor;
		-webkit-transform: scaleX(1);
		transform: scaleX(1);
		transform-origin: center;
	}

	.concept42.viewport-mobile .showcase-slider-parallax .c42-pagination-bullet::before {
		content: "";
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		height: 1px;
		background-color: currentColor;
		-webkit-transform: scaleX(0);
		transform: scaleX(0);
		transform-origin: right;
		-webkit-transition: transform 0.2s ease-in-out 0.1s;
		transition: transform 0.2s ease-in-out 0.1s;
	}

	.concept42.viewport-mobile .showcase-slider-parallax .c42-pagination-bullet.c42-pagination-bullet-active::before {
		transform-origin: left;
		-webkit-transform: scaleX(1);
		transform: scaleX(1);
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet .bullet-number-wrapper {
		display: flex;
		align-items: center;
		justify-content: center;
		width: auto;
		height: 100%;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet .bullet-number {
		position: relative;
		width: auto;
		height: 100%;
		opacity: 0.2;
		pointer-events: initial;
		-webkit-transition: opacity 0.2s ease-in-out;
		transition: opacity 0.2s ease-in-out;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet.c42-pagination-bullet-active .bullet-number,
	.concept42 .showcase-slider-parallax .c42-pagination-bullet .bullet-number-wrapper:hover .bullet-number {
		opacity: 1;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet .c42-autoplay-progress {
		position: absolute;
		bottom: -1px;
		left: 0;
		width: 100%;
		height: 3px;
		opacity: 0;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet.c42-pagination-bullet-active .c42-autoplay-progress {
		opacity: 1;
	}

	.concept42 .showcase-slider-parallax .c42-pagination-bullet .c42-autoplay-progress span {
		position: relative;
		display: block;
		width: 0%;
		height: 2px;
		background: currentColor;
	}

	/* Responsive */

	@media only screen and (max-width: 1024px) {

		.concept42 .c42-slider-wrapper .c42-slider-caption .item-caption {
			flex-direction: column;
			align-items: flex-start;
			justify-content: center;
			text-align: left;
		}

		.concept42 .c42-slider-wrapper .c42-slider-caption .item-role {
			text-align: left;
		}

	}

	@media only screen and (max-width: 767px) {

		.concept42 .c42-pagination-bullet {
			padding-bottom: 30px;
		}

	}

	@media only screen and (max-width: 479px) {

		.concept42 .c42-pagination-bullet {
			padding-bottom: 20px;
		}

	}



/*------------------------------------------------------------------
    Showcase Slider Carousel Horizontal
-------------------------------------------------------------------*/

	.concept42 .c42-slider-wrapper .c42-carousel-caption-wrapper {
		position: absolute;
		top: calc(50 * var(--dvh, 1vh) + max(10vw, 140px));
		left: 0;
		z-index: 100;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		width: calc(100vw - var(--scroll-bar-w));
		height: 100px;
		box-sizing: border-box;
		opacity: 0;
		pointer-events: none;
		-webkit-transition: opacity 0.2s ease-in-out;
		transition: opacity 0.2s ease-in-out;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption-wrapper.visible-caption {
		opacity: 1;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption {
		position: relative;
		display: flex;
		align-items: flex-start;
		justify-content: center;
		width: 20vw;
		min-width: 280px;
		height: 100px;
		opacity: 1;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-caption {
		position: absolute;
		text-align: center;
		color: currentColor;
		pointer-events: none;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-title {
		position: relative;
		overflow: hidden;
		font-family: var(--primary-font-family);
		font-size: var(--h5-font-size);
		line-height: var(--h5-line-height);
		font-weight: var(--h5-font-weight);
		letter-spacing: var(--h5-letter-spacing);
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-cat {
		overflow: hidden;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-title span,
	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-cat span {
		position: relative;
		display: block;
		opacity: 0;
	}

	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-caption.active .item-title span,
	.concept42 .c42-slider-wrapper .c42-carousel-caption .item-caption.active .item-cat span {
		opacity: 1;
	}

	.concept42 .showcase-slider-carousel-horizontal .c42-slide .item-date {
		position: absolute;
		top: -23px;
		right: 12px;
		left: auto;
		display: block;
		padding: 0;
		overflow: hidden;
		text-align: right;
		background: transparent;
		opacity: 0;
		color: currentColor;
		-webkit-transition: opacity 0.2s ease-in-out;
		transition: opacity 0.2s ease-in-out;
	}

	.concept42 .showcase-slider-carousel-horizontal.visible-caption .c42-slide .item-caption .item-date {
		opacity: 0.2;
	}

	.concept42 .showcase-slider-carousel-horizontal .c42-slide:hover .item-caption .item-date {
		opacity: 1;
	}

	.concept42 .showcase-slider-carousel-horizontal .c42-slide .item-date span {
		position: relative;
		display: block;
		text-align: right;
		-webkit-transform: translateY(100%);
		transform: translateY(100%);
		-webkit-transition: transform 0.2s ease-in-out;
		transition: transform 0.2s ease-in-out;
	}

	.concept42 .showcase-slider-carousel-horizontal .c42-slide .item-date span::after {
		content: var(--slide-index);
		position: absolute;
		top: -100%;
		right: 0;
		width: 100%;
		height: 100%;
	}

	.concept42 .showcase-slider-carousel-horizontal .c42-slide:hover .item-caption .item-date span {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

	/* Responsive */

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .c42-slider-viewport {
		transform: translateY(calc(-1 * var(--hero-footer-height) / 2));
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption {
		position: absolute;
		top: 0;
		bottom: auto;
		display: flex;
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
		height: calc(100% + 36px);
		padding: 12px;
		opacity: 0;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption .item-title {
		position: relative;
		display: block;
		overflow: hidden;
		color: currentColor;
		-webkit-transition: all 0.2s ease-in-out;
		transition: all 0.2s ease-in-out;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-content:hover .item-caption .item-title {
		padding-left: 30px;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption .item-title::before {
		content: "\f061";
		position: absolute;
		top: 0;
		left: 0;
		width: 20px;
		height: 30px;
		font: var(--fa-font-solid);
		font-size: 12px;
		line-height: inherit;
		text-align: left;
		opacity: 0;
		color: currentColor;
		pointer-events: none;
		-webkit-transform: scale(0.5) rotate(-45deg);
		transform: scale(0.5) rotate(-45deg);
		transform-origin: -10px center;
		-webkit-transition: all 0.2s ease-in-out;
		transition: all 0.2s ease-in-out;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-content:hover .item-caption .item-title::before {
		opacity: 1;
		-webkit-transform: scale(1) rotate(0deg);
		transform: scale(1) rotate(0deg);
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption .item-cat {
		position: relative;
		display: block;
		overflow: hidden;
		color: currentColor;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption .item-cat span {
		position: relative;
		display: block;
		width: auto;
		min-width: 100px;
		text-align: right;
		-webkit-transition: -webkit-transform 0.2s;
		transition: transform 0.2s;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-caption .item-cat span::before {
		content: attr(data-hover);
		position: absolute;
		top: 100%;
		right: 0;
		width: 100%;
		height: 100%;
	}

	.concept42.viewport-mobile .showcase-slider-carousel-horizontal .item-content:hover .item-caption .item-cat span {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
	}



/*------------------------------------------------------------------
    Portfolio Grid
-------------------------------------------------------------------*/

	.concept42 .filters-wrapper {
		position: relative;
		z-index: 1000;
		display: flex;
		justify-content: flex-start;
		width: 100%;
		height: 0;
		box-sizing: border-box;
		padding-top: 0;
		padding-bottom: 0;
		background-color: rgb(200, 200, 200);
		mask-image: none !important;
		opacity: 0;
		pointer-events: none;
	}

	.concept42 .filters-container {
		position: relative;
		width: 100%;
		height: auto;
		padding-top: 35px;
		padding-left: calc(33.3333% - (2 * var(--gap)) / 3 + var(--gap));
		padding-bottom: 25px;
	}

	.concept42 .c42-item .reveal-overlay {
		position: absolute;
		inset: 0;
		z-index: 5;
		display: flex;
		pointer-events: none;
		transform: scaleX(1.01);
	}

	.concept42 .c42-item .reveal-overlay span {
		flex: 1;
		background: #f7f7f7;
		transform-origin: top;
		transform: scaleX(1.1) scaleY(1);
		will-change: transform;
	}

	.concept42 .c42-item .reveal-overlay span:nth-child(3) {
		flex: 2;
	}

	.concept42 .showcase-portfolio {
		padding-top: 35px;
		counter-reset: thumb;
	}

	/* List View */

	.concept42 .showcase-portfolio.portfolio-list-view {
		padding-top: 60px;
		row-gap: 0;
	}

	.concept42 .showcase-portfolio.portfolio-list-view .c42-item::after {
		--segment: calc(
			(100% - (var(--horizontal-gutter) * 2) - (var(--gap) * 2)) / 3
		);
		mask-image: linear-gradient(
			to right,
			transparent 0,
			transparent var(--horizontal-gutter),
			black var(--horizontal-gutter),
			black calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent 100%
		);
	}

	.concept42.viewport-mobile .showcase-portfolio.portfolio-list-view .c42-item .item-effects {
		right: 0;
		left: 0;
		width: 100px;
		margin: auto;
	}

	/* Grid View */

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item {
		display: flex;
		width: calc(50% - (2 * var(--thumbs-margins-width)));
		overflow: hidden;
		padding-top: 35px;
		padding-bottom: 45px;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	.concept42 .showcase-portfolio.items-filtered:not(.portfolio-list-view) .c42-item {
		width: calc(33.33% - (2 * var(--thumbs-margins-width)));
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content {
		position: relative;
		display: flex;
		width: 100%;
		height: auto;
		cursor: pointer;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	/* Thumb 1 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(1) {
		align-items: flex-start;
		justify-content: flex-start;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(1)::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(1) .item-content {
		width: 100%;
	}

	/* Thumb 2 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(2) {
		align-items: flex-end;
		justify-content: flex-end;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(2)::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(2) .item-content {
		width: 66.6667%;
	}

	/* Thumb 3 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(3) {
		align-items: flex-end;
		justify-content: flex-end;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(3)::before {
		display: none;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(3) .item-content {
		width: 50%;
	}

	/* Thumb 4 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(4) {
		align-items: flex-end;
		justify-content: flex-start;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(4)::before {
		display: none;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(4) .item-content {
		width: 50%;
	}

	/* Thumb 5 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(5) {
		align-items: flex-start;
		justify-content: flex-start;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(5)::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(5) .item-content {
		width: 66.6667%;
	}

	/* Thumb 6 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(6) {
		align-items: flex-start;
		justify-content: flex-start;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(6)::before {
		content: "";
		float: left;
		padding-top: 90%;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(6) .item-content {
		width: 100%;
	}

	/* Thumb 7 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(7) {
		align-items: flex-end;
		justify-content: flex-end;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(7)::before {
		display: none;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(7) .item-content {
		width: 50%;
	}

	/* Thumb 8 */

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(8) {
		align-items: flex-end;
		justify-content: flex-start;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(8)::before {
		display: none;
	}

	.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(8) .item-content {
		width: 50%;
	}

	/* Thumb Caption */

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption {
		display: flex;
		flex-direction: row;
		align-items: flex-end;
		justify-content: space-between;
		height: calc(100% + 45px);
		padding: 0;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-title {
		color: currentColor;
		-webkit-transition: all 0.2s ease-in-out;
		transition: all 0.2s ease-in-out;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content:hover .item-caption .item-title {
		padding-left: 30px;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-title::before {
		content: "\f061";
		position: absolute;
		top: 0;
		left: 0;
		width: 20px;
		height: 30px;
		font: var(--fa-font-solid);
		font-size: 12px;
		line-height: inherit;
		text-align: left;
		opacity: 0;
		color: currentColor;
		pointer-events: none;
		-webkit-transform: scale(0.5) rotate(-45deg);
		transform: scale(0.5) rotate(-45deg);
		transform-origin: -10px center;
		-webkit-transition: all 0.2s ease-in-out;
		transition: all 0.2s ease-in-out;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content:hover .item-caption .item-title::before {
		opacity: 1;
		-webkit-transform: scale(1) rotate(0deg);
		transform: scale(1) rotate(0deg);
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-cat {
		color: currentColor;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-cat span {
		position: relative;
		display: block;
		width: auto;
		min-width: 100px;
		text-align: right;
		-webkit-transition: -webkit-transform 0.2s;
		transition: transform 0.2s;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-cat span::before {
		content: attr(data-hover);
		position: absolute;
		top: 100%;
		right: 0;
		width: 100%;
		height: 100%;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content:hover .item-caption .item-cat span {
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-date {
		position: absolute;
		top: -35px;
		right: 0;
		left: auto;
		display: block;
		padding: 0;
		text-align: right;
		background: transparent;
		color: currentColor;
	}

	.concept42 .showcase-portfolio.portfolio-list-view .c42-item .item-date {
		text-align: right;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-date span {
		text-align: right;
		-webkit-transform: translateY(-100%);
		transform: translateY(-100%);
		-webkit-transition: -webkit-transform 0.2s;
		transition: transform 0.2s;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .item-caption .item-date span::after {
		content: counter(thumb, decimal-leading-zero) "";
		position: absolute;
		top: 100%;
		right: 0;
		width: 100%;
		height: 100%;
		counter-increment: thumb;
	}

	.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item .item-content:hover .item-caption .item-date span {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}

	/* Responsive */

	@media only screen and (max-width: 1024px) {

		/* Thumb 3 */
		.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(3) .item-content {
			width: 66.6667%;
		}

		/* Thumb 4 */
		.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(4) .item-content {
			width: 66.6667%;
		}

		/* Thumb 7 */
		.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(7) .item-content {
			width: 66.6667%;
		}

		/* Thumb 8 */
		.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(8) .item-content {
			width: 66.6667%;
		}

	}

	@media only screen and (max-width: 767px) {

		.concept42 .filters-container {
			padding-left: 0;
		}

		/* All Thumbs */
		.concept42 .showcase-portfolio:not(.items-filtered):not(.portfolio-list-view) .c42-item:nth-child(n) .item-content {
			width: 100%;
		}
		
		.concept42 .showcase-portfolio.items-filtered:not(.portfolio-list-view) .c42-item {
		  	width: calc(50% - (2 * var(--thumbs-margins-width)));
		}

	}

	@media only screen and (max-width: 479px) {

		.concept42 .showcase-portfolio:not(.portfolio-list-view) .c42-item {
			width: calc(100% - (2 * var(--thumbs-margins-width)));
		}
		
		.concept42 .showcase-portfolio.items-filtered:not(.portfolio-list-view) .c42-item {
		  	width: calc(100% - (2 * var(--thumbs-margins-width)));
		}

		.concept42 .showcase-portfolio.switch-layout.portfolio-list-view .c42-item .item-caption {
			flex-wrap: wrap;
			align-content: center;
			gap: 0;
		}

		.concept42 .showcase-portfolio.switch-layout.portfolio-list-view .c42-item .item-caption .item-title {
			flex: 0 0 100%;
		}

		.concept42 .showcase-portfolio.switch-layout.portfolio-list-view .c42-item .item-caption .item-cat,
		.concept42 .showcase-portfolio.switch-layout.portfolio-list-view .c42-item .item-caption .item-date {
			flex: 0 0 50%;
		}

	}


/*------------------------------------------------------------------
    Shortcodes
-------------------------------------------------------------------*/

	/* Has Underline */

	.concept42 .clone-underline::before,
	.concept42 .clone-underline::after {
		bottom: 8px;
	}

	@media only screen and (max-width: 1537px) {

		.concept42 .clone-underline::before,
		.concept42 .clone-underline::after {
			bottom: 7px;
		}

	}

	@media only screen and (max-width: 1024px) {

		.concept42 .clone-underline::before,
		.concept42 .clone-underline::after {
			bottom: 5px;
		}

	}

	/* Marquee */

	.concept42 .marquee-image {
		width: 1em;
		height: 1em;
	}	

	/* Flex List */

	.concept42 .flex-list::before {
		--segment: calc(
			(100% - (var(--horizontal-gutter) * 2) - (var(--gap) * 2)) / 3
		);
		mask-image: linear-gradient(
			to right,
			transparent 0,
			transparent var(--horizontal-gutter),
			black var(--horizontal-gutter),
			black calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment)),
			transparent calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) + var(--gap)),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap)),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 2 + var(--gap) * 2),
			black calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent calc(var(--horizontal-gutter) + var(--segment) * 3 + var(--gap) * 2),
			transparent 100%
		);
	}

	/* Clock */

	.concept42 .clock-widget {
		align-items: inherit;
		justify-content: center;
	}

	@media only screen and (max-width: 767px) {

		.concept42 .clock-widget {
			flex-direction: row;
			gap: 4px;
		}

		.concept42 .clock-label::after {
			content: ",";
		}

		.concept42 .clock-time.heading-5 {
			font-family: var(--default-font-family);
			font-size: var(--default-body-font-size);
			line-height: var(--default-body-line-height);
			font-weight: var(--default-body-font-weight);
			letter-spacing: var(--default-body-letter-spacing);
		}

	}

	/* Background Pattern */

	.concept42 .background-pattern {
		--checker-opacity: 0.1;
		--checker-size: 18px;
		--checker-color: color-mix(in srgb, currentColor calc(var(--checker-opacity) * 100%), transparent);
		background-color: transparent;
		background-image:
			linear-gradient(45deg, var(--checker-color) 25%, transparent 25%),
			linear-gradient(-45deg, var(--checker-color) 25%, transparent 25%),
			linear-gradient(45deg, transparent 75%, var(--checker-color) 75%),
			linear-gradient(-45deg, transparent 75%, var(--checker-color) 75%);
		background-size: var(--checker-size) var(--checker-size);
		background-position: 0 0, 0 calc(var(--checker-size) / 2), calc(var(--checker-size) / 2) calc(var(--checker-size) / -2), calc(var(--checker-size) / -2) 0;
	}

	.clients-table-slider.cols-3 .clients-table { --cols: 3; }
	.clients-table-slider.cols-5 .clients-table { --cols: 5; }