.nf-field-label .nf-label-span,
.nf-field-label label {
	font-weight: 600 !important;
}

.nf-form-fields-required,
.nf-error-msg.nf-error-field-errors {
	display: none !important;
}

.nf-error-msg {
	font-size: 16px !important;
	color: var(--tt-main-color) !important;
}

.nf-error .ninja-forms-field {
	border-color: var(--tt-main-color) !important;
}

.ninja-forms-req-symbol {
	color: inherit !important;
}


.nf-field-container .checkbox-wrap input[type=checkbox],
.nf-field-container .list-radio-wrap input[type=radio] {
	-webkit-appearance: none;
	background-color: #d1d1d1;
	padding: 9px;
	border-radius: 4px;
	display: inline-block;
	position: relative;
}


.nf-field-container .checkbox-wrap .nf-field-label {
	padding-left: 0 !important;
}

.nf-field-container .checkbox-wrap label {
	display: inline-block;
	margin-left: 32px;
	margin-bottom: 0;
	cursor: pointer !important;
	font-weight: 800 !important;
	color: #840d7a !important;

}

.nf-field-container .checkbox-wrap input[type=checkbox]:checked:after {
	content: ' ';
	left: 6px;
	top: 3px;
	width: 5px;
	height: 10px;
	position: absolute;
	border: solid #000;
	border-width: 0 2px 2px 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

.nf-field-container .checkbox-wrap input[type=checkbox] {
	margin-top: 0;
}

#ninja_forms_required_items,
.nf-field-container {
	margin-bottom: 30px !important;
}

.nf-field-container .checkbox-wrap input[type=checkbox]:checked {
	color: #99a1a7;
	/*box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0px -15px 10px -12px rgba(0,0,0,0.05), inset 15px 10px -12px rgba(255,255,255,0.1), inset 0px 0px 10px rgba(0,0,0,0.1);*/
}

.nf-field-container .checkbox-wrap input[type=checkbox]:active,
.label-right .checkbox-wrap input[type=checkbox]:checked:active {
	/*box-shadow: 0 1px 2px rgba(0,0,0,0.05), inset 0px 1px 3px rgba(0,0,0,0.1);*/
}

.cta-btns-wrapper {
	display: flex;
	flex-wrap: wrap;
}

.cta-btns-wrapper.right:not(.overlapping) {
	justify-content: flex-end;
}

.cta-btns-wrapper.overlapping {
	flex-direction: column;
}

.cta-btns-wrapper.overlapping.left .tt-btn {
	margin-right: auto;
}

.cta-btns-wrapper.center {
	align-items: center;
	justify-content: center;
}

.cta-btns-wrapper.right .tt-btn {
	margin-left: auto;
	margin-right: 0;
}

.cta-btns-wrapper.right:not(.overlapping) .tt-btn {
	margin-left: 15px;
	margin-right: 0;
}

.cta-btns-wrapper.overlapping.right .tt-btn {
	margin-right: 0;
}

.cta-btns-wrapper .tt-btn {
	flex-grow: 0
}

.img-wrapper {
}

.img-wrapper img {
	aspect-ratio: 1 / 1;
	max-width: 300px !important;
	display: block;
	width: 90%;
}

.img-wrapper.center img {	
	margin-left: auto;
	margin-right: auto;
}

.img-wrapper.left img {
	margin-left: 0;
	margin-right: auto;
}

.img-wrapper.right img {
	margin-left: auto;
	margin-right: 0;
}
 
@media (max-width: 1024px) {
	.img-wrapper {
		margin-left: 0;
	}

}

/*@media (min-width: 1024px) and (max-width: 1109px) {
	.tt-main-menu-list > li	{
		padding: 0 10px;
	}
	
	.tt-main-menu-list > li > a {
		padding: 20px 3px;
		font-size: 13px;
	}
}*/

textarea {
	resize: none !important;
}

.margin-top-neg-20 {
	margin-top: -20px !important;
}

.tt-section.text-white,
.tt-section.text-white p,
.tt-section.text-white ul,
.tt-section.text-white ol,
.tt-section.text-white li,
.tt-section.text-white h1,
.tt-section.text-white h2,
.tt-section.text-white h3,
.tt-section.text-white h4,
.tt-section.text-whiteh h5,
.tt-section.text-white h6 {
	color: #fff;
}

/*
.tt-section.fixed-bg .tt-section-image > img,
.tt-section.fixed-bg .anim-image-parallax-inner img {
	height: 100%;
	object-fit: cover;
}*/

.tt-blog-post-tags a {
	pointer-events: none;
	user-select: none;
}

ul.ttgr-cat-classic-list,
ul.ttgr-cat-classic-list>li,
ul.ttgr-cat-classic-list>li>a {
	user-select: none;
}

.tt-submenu-trigger.no-arrow>a::after {
	display: none;
}

@media (min-width: 1025px) {
	.tt-submenu {
		width: auto;
		padding-right: 20px;
	}

	.tt-submenu.lang-selection {
		left: -20px;
	}
}

.lang-menu>a {
	pointer-events: none;
}

.tt-m-menu-toggle-btn span.change-color::before,
.tt-m-menu-toggle-btn span.change-color::after {
	background-color: var(--tt-main-color) !important;
}

@media (max-width: 1024px) {
	#content-wrap>.tt-section:first-child {
		padding-top: 120px;
	}
}

.portfolio-grid .logo-title-wrapper {
	display: flex;
	flex-direction: column;
	/* Laita logo ja otsikko pystysuoraan */
	justify-content: center;
	/* Keskittää pystysuunnassa */
	align-items: center;
	/* Keskittää vaakasuunnassa */
}

.portfolio-grid .pgi-caption-inner {
	display: flex;
	flex-direction: column;
	/* Varmistaa, että logo ja otsikko ovat pystysuorassa */
	justify-content: left;
	/* Keskittää pystysuunnassa */
	align-items: flex-start;
	/* Keskittää vaakasuunnassa */
	height: 100%;
	/* Varmistaa, että täyttää koko tilan pystysuunnassa */
	text-align: left;

}


.portfolio-grid .portfolio-logo {
	width: auto;
	height: 60px;
	filter: brightness(0) invert(1);
	/*transform-origin: 50% 0%;*/
}

@media (max-width: 1024px) {
	.portfolio-grid .portfolio-logo {
		width: auto;
		height: 60px;


	}
}

.portfolio-grid.pgi-cap-inside .pgi-caption {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	/* Varmistaa, että elementti täyttää koko käytettävissä olevan tilan */
	padding: 0 8%;
	z-index: 2;
	text-align: center;
}


.portfolio-grid .flex-container {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100%;
	text-align: center;
	margin-top: 10%;
}

.portfolio-grid .pgi-caption h2 {
	margin-top: 2vw;
	margin-bottom: 0;
	display: none;
}

.portfolio-grid .content-wrapper {
	max-height: 180px;
	text-align: center;
	display: inline-block;
	/* Vain tarvittavan korkuinen */
}

/* Kauttaviivoin erotetut filtterit */

ul.ttgr-cat-classic-list {
	padding: 0;
	margin: 0;
	list-style: none;
	text-align: left;
	margin: 0 40px 0 0px;
}

ul.ttgr-cat-classic-list>li {
	display: inline;
	/*	Järjestää linkit vierekkäin	*/
	margin: 0;
	/* Poistetaan marginaalit */
	/*white-space: nowrap;*/
}

ul.ttgr-cat-classic-list>li:not(:last-child)::after {
	content: " / ";
	/* Lisää kauttaviivan kategorioiden	väliin */
	color: #0a0a0a;
	/* Kauttaviivan	väri */
	margin-left: 4px;
	margin-right: 4px;
}

ul.ttgr-cat-classic-list>li>a {
	background-color: transparent;
	border: none;
	border-bottom: 1px solid;
	padding: 0;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.8;
	color: #0a0a0a;
	transition: color 0.3s;
	opacity: .8;
}


@media (max-width: 1024px) {
	ul.ttgr-cat-classic-list>li>a {

		font-size: 12px;
		font-weight: 400;
		line-height: 1.4;

	}

}

ul.ttgr-cat-classic-list>li>a:hover,
ul.ttgr-cat-classic-list>li>a.active {
	color: var(--tt-main-color);
	/*	Vaihda väri	hoverilla ja aktiivisessa tilassa */

}


.ttgr-cat-classic-nav.ttgr-cat-classic-colored ul.ttgr-cat-classic-list>li>a:hover {
	background: none;
	opacity: 1;
}

.ttgr-cat-classic-nav.ttgr-cat-classic-colored ul.ttgr-cat-classic-list>li>a.active {
	background: none;
	font-weight: 600;
}

.ref-list-description {
	transform: scale(0.8);
	transform-origin: 50% 50%;
}

.tt-section:not(.text-white) .cta-btns-wrapper .tt-btn-line {
	background-color: #0a0a0a !important;
}

.mobile-nav-contacts {
	color: #0a0a0a;
	margin: 40px 0;
	font-size: 16px;
	margin-top: 80px;
	letter-spacing: -0.01em;
}

.mobile-nav-contacts a {
	color: inherit !important;
	font-size: inherit !important;
}


.round-image {
	border-radius: 100px;
}


.tt-accordion .tt-accordion-heading .tt-ac-head-title .icon {
	display: inline-block;
	min-width: 1.6em;
}

.tt-grid-item .play-icon {
	color: white;
	font-size: clamp(40px, 8vw, 80px);
	/* Minimissään 50px, maksimissaan 100px, ja suhteellinen 10vw */
	position: absolute;
	top: 50%;
	/* Keskittää pystysuunnassa */
	left: 50%;
	/* Keskittää vaakasuunnassa */
	transform: translate(-50%, -50%);
	/* Täsmällinen keskitys */
	z-index: 99;
	opacity: 1;
	transition: opacity 500ms ease-in-out;
	pointer-events: none;
	/* Estää kuvakkeen klikkaukset */
}

.tt-grid-item:hover .play-icon {
	opacity: 0;
}


#page-header .credits {
	position: absolute;
	color: #fff;
	font-size: 10px;
	right: 15px;
	bottom: 10px;
	z-index: 180;
	user-select: none;
	opacity: 0.7;
	letter-spacing: 0.03em;
}

@media (max-width: 767px) {
	#page-header .credits {
		display: none;
	}

}


@media (max-width: 1024px) {
	.padding-top-400 {
		padding-top: 400px !important;
	}
}

.tt-logo {
	transition: opacity 500ms ease-in-out;
}

body.tt-ol-menu-open .tt-logo {
	opacity: 1 !important;
}


/* Grid-laajennokset by RFM */


/* ttgr-layout-square */
.tt-grid.ttgr-layout-square .ttgr-height {
	aspect-ratio: 1 / 1;
	/* Määritetään neliön muotoinen kuvasuhde */
}

/* Yhteensopivuus muiden layout-luokkien kanssa */
/*.tt-grid.ttgr-layout-2-3.ttgr-layout-square .ttgr-height,
.tt-grid.ttgr-layout-3-2.ttgr-layout-square .ttgr-height,
.tt-grid.ttgr-layout-3-4.ttgr-layout-square .ttgr-height {
    aspect-ratio: 1 / 1;
}*/

/* ttgr-layout-1-2-3 */
.tt-grid.ttgr-layout-1-2-3 .tt-grid-item {
	width: 100%;
}

/* Täysleveät kuvat square-moodissakin matalampia */
.tt-grid.ttgr-layout-square.ttgr-layout-1-2 .tt-grid-item:first-child .ttgr-height,
.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:first-child .ttgr-height,
.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3 .tt-grid-item:first-child .ttgr-height,
.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+1) .ttgr-height,
.tt-grid.ttgr-layout-square.ttgr-layout-1-2 .tt-grid-item:nth-child(3n+1) .ttgr-height {
	aspect-ratio: auto;
	padding-bottom: 49%;
}


.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+2),
.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+3) {
	width: 50%;
}

.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+4),
.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+5),
.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+6) {
	width: 33.33333%;
}

/* Media Queries for ttgr-layout-1-2-3 */

/* Tabletit: 768px - 1024px */
@media (min-width: 768px) and (max-width: 1024px) {
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+1) {
		width: 100%;
	}

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+2),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+3) {
		width: 50%;
	}

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+4),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+5),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+6) {
		width: 33.33333%;
	}
}

/* Näytöt: yli 1025px */
@media (min-width: 1025px) {
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+1) {
		width: 100%;
	}

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+2),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+3) {
		width: 50%;
	}

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+4),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+5),
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+6) {
		width: 33.33333%;
	}
}


/* ttgr-layout-1-2-3-loop */
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+1) {
	width: 100%;
}

.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+2),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+3) {
	width: 50%;
}

.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+4),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+5),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+6) {
	width: 33.33333%;
}

/* Jatkuva kaava: 1-2-3-1-2-3... */
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+7) {
	width: 100%;
}

.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+8),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+9) {
	width: 50%;
}

.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+10),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+11),
.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+12) {
	width: 33.33333%;
}


/* Media Queries for ttgr-layout-1-2-3-loop */

/* Alle 768px: 100% leveät kuvat */
@media (max-width: 767px) {

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item,
	.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item {
		width: 100% !important;
	}

	.tt-grid.ttgr-layout-1-2 .tt-grid-item .ttgr-height,
	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item .ttgr-height,
	.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item .ttgr-height {
		padding-bottom: 70% !important;
	}

	.tt-grid.ttgr-layout-square.ttgr-layout-1-2 .tt-grid-item:first-child .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:first-child .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3 .tt-grid-item:first-child .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+1) .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2 .tt-grid-item:nth-child(3n+1) .ttgr-height {
		aspect-ratio: 1 / 1 !important;
	}

}

/* 768px - 1024px: 50% leveät kuvat */
@media (min-width: 768px) and (max-width: 1024px) {

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item,
	.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item {
		width: 50% !important;
	}

	.tt-grid.ttgr-layout-1-2-3 .tt-grid-item .ttgr-height,
	.tt-grid.ttgr-layout-1-2-3-loop .tt-grid-item .ttgr-height {
		padding-bottom: 70% !important;
	}

	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:first-child .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3 .tt-grid-item:first-child .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3-loop .tt-grid-item:nth-child(6n+1) .ttgr-height,
	.tt-grid.ttgr-layout-square.ttgr-layout-1-2-3 .tt-grid-item:nth-child(3n+1) .ttgr-height {
		aspect-ratio: 1 / 1 !important;
	}
}

/* Grid-laajennokset By RFM päättyy */

.tt-grid.zoom-effect .tt-grid-item .pgi-image {
	transition: all 1s cubic-bezier(.165, .84, .44, 1);
}

.tt-grid.zoom-effect .pgi-image:hover {
	transform: scale(1.05);
}


.breadcrumb-wrapper {
	font-size: 14px;
	margin-bottom: 40px;
	cursor: default;
}

.breadcrumb-wrapper a {
	transition: all 0.2s ease-in-out;
}

.breadcrumb-wrapper a:hover {
	opacity: .6;
}


.tt-section.text-white .tt-btn-link *,
.tt-section.text-white .tt-btn-link *::after {
	color: #fff !important;
}


/*
@media (max-width: 767px) {
	.tt-grid.portfolio-samples .tt-grid-item {
		width: 50%;
	}
}
*/



@media (max-width: 540px) {
	.tt-bp-nav-left {
		border: none;
	}
}

.tt-scroll-down {
	left: 4%;
}

#page-header.ph-left {
	text-align: left;
}

#page-header.ph-right {
	text-align: right;
}

.page-header-inner .ph-logo {
	width: 500px;
	max-width: 100%;
	margin: 0 auto;
	margin-bottom: 60px;
}

.page-header-inner .ph-logo img {
	max-height: 260px;
}

.tt-logo-wall.no-border>li {
	
	border-width: 0;
	
}

.tt-section.no-overlay>div.cover-opacity-5::before {
	
	opacity: 0;
	
}

.tt-section.columns  iframe {
	width: 100% !important;
	height: auto !important;
	aspect-ratio: 16 / 9;
}

.breadcrumbs {
	color: #652d90;
	font-size: 15px;
	font-weight: 600;
	padding-bottom: 40px;
	cursor: default;
}

body.page-header-on .breadcrumbs {
	padding-bottom: 0;
}

.breadcrumbs i.fas {
    margin: 0 10px; /* Vähensin marginaalia, mutta voit säätää tarpeen mukaan */
    transform: scale(0.6); /* Skaalaus pysyy samana */
    vertical-align: middle; /* Keskittää ikonin vertikaalisesti tekstin kanssa */
    position: relative;
    top: 0px; /* Säädä arvoa tarpeen mukaan, esim. 1px, 2px, 3px jne. */
}

.lg-sub-html {
	color: #fff !important;
	font-weight: 600 !important;
	font-size: 16px;
	letter-spacing: 0.01em;
}


#gtranslate_wrapper, .gt_float_switcher, .gt_switcher_wrapper {
	display: none !important;
}

.rounded-img {
	border-radius: 15px;
}

.tt-blog-post-content img {
	border-radius: 15px;
}









.quote-widget {
	background-color: #ffffff;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 40px;
	margin-bottom: 40px;
}

.quote-widget .quote-card {
	position: relative;
	background: linear-gradient(135deg, #efeff1, #f8f8f8);
	border-radius: 20px;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);	
	padding: 2.5rem 3.5rem 5rem 2.5rem;
	/*margin-right: 45px;
	margin-left: 30px;
	max-width: 500px;*/
	max-width: 468px;
	position: relative;
}

.quote-widget .profile-img {
	position: absolute;
	top: -70px;
	right: 70px;
	width: 140px;
	height: 140px;
	border-radius: 50%;
	border: 5px solid #fff;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
	user-select: none;
	pointer-events: none;
}

.quote-widget .profile-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.quote-widget blockquote {
	margin: 0;
	padding-top: 1.3rem;
	padding-left: 1.3rem;
	color: #57597a;
	font-size: 1rem;
	line-height: 1.5;
	text-align: left;
	border: none;
	text-decoration: none;
	font-style: normal;
}

.quote-widget blockquote .quote-mark {
	font-size: 3rem;
	color: #CDCED7;
	margin-bottom: 1rem;
	display: block;
}

.quote-widget cite {
	display: block;
	margin-top: 1.5rem;
	font-weight: bold;
	color: #57597a;
	font-style: normal;
}


@media (max-width: 991px) {
	.quote-widget .profile-img {
		top: -70px;
		right: 50px;
	}
}


@media (max-width: 767px) {

	.quote-widget blockquote .quote-mark {
		font-size: 2rem;
	}

	.quote-widget .quote-card {
		padding: 1.5rem 2.5rem 2.5rem 1.5rem;
	}

	.quote-widget blockquote {
		font-size: 1.1rem;
	}

	.quote-widget .profile-img {
		transform: scale(0.7);
		transform-origin: center bottom;
		top: -100px;
		right: 20px;
	}
}

@media (max-width: 400px) {
	.quote-widget .profile-img {
		transform: scale(0.5);
		transform-origin: center bottom;
		top: -108px;
		right: 0;	
	}

}

.gradient-icon {
  background: linear-gradient(45deg, #292c9b, #039dfc);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  display: inline-block;
}

.nf-field-description {
	text-align: left !important;
}

.nf-field-description p {
	font-size: 16px;
	margin-bottom: 20px !important;
}

.field-wrap.file_upload-wrap {
	text-align: left !important;
}

.btn.nf-fu-fileinput-button {
	background: #57597a;
	color: #fff;
	font-size: 16px;
	padding: 10px;
	border-radius: 5px;
}

.nf-fu-progress {
	display: none;
}

.tt-section ul.fa-ul li .fa-arrow-right-long {
	color: #292c9b;
}

.ph-category.date {
	color: #652d90!important;
}

.tt-blog-post-content ul.fa-ul {
	font-weight: 600;
}

body.page-header-on:not(.tt-ph-visible) #tt-header.tt-header-fixed {
	box-shadow: 0 1px 28px -8px rgba(0, 0, 0, .25);
}

/* Loaderin animointi */
.ptr-prel-image {
	animation: pulse 2.5s ease-in-out infinite;
	transform-origin: center center;
}

@keyframes pulse {
	0% {
		transform: scale(1);
		opacity: .5;
	}
	50% {
		transform: scale(1.08);
		opacity: 0.2;
	}
	100% {
		transform: scale(1);
		opacity: .5;
	}
}

@media (max-width: 767px) {
	.tt-grid-item {
		height: auto !important;
	}
}

.tt-grid-item p:last-child {
	margin-bottom: 0 !important;	
}

.staff-member {
	width: 400px;
}

@media (max-width: 767px) {
	.staff-member {
		display: block;
		margin-left: auto;
		margin-right: auto;
		width: 100%;
		max-width: 200px !important;
		height: auto;
	}
}

.bio-text,
.bio-text p {
	font-size: 18px;
}


/* Cookiebot */

#CybotCookiebotDialog {
	border-radius: 0 !important;
}


#CybotCookiebotDialog *,
#CybotCookiebotDialogBodyUnderlay * {
	font-family: "jaf-domus", sans-serif !important;
}

#CybotCookiebotDialogFooter .CybotCookiebotDialogBodyButton {
	padding: 0.8em 0.5em !important;
	font-size: 1rem !important;
	border-radius: 5px !important;
	border-width: 1px !important;
	font-weight: 600 !important;
	text-transform: uppercase;
}

#CybotCookiebotDialogFooter #CybotCookiebotDialogBodyButtonAccept, #CybotCookiebotDialogFooter #CybotCookiebotDialogBodyLevelButtonAccept, #CybotCookiebotDialogFooter #CybotCookiebotDialogBodyLevelButtonLevelOptinAllowAll {
	border-color: #652d90!important;
	text-transform: uppercase;
	font-size: 16px;	
	font-weight: 600;
}

.CybotCookiebotDialogDetailBodyContentCookieInfo,
.CybotCookiebotDialogDetailBodyContentCookieGroup,
.CybotCookiebotDialogDetailBodyEmptyCategoryMessage {
	border-radius: 0 !important;
}

#CybotCookiebotDialogBodyContentTitle {
	font-size: 1.2rem !important;
	line-height: 1.5em !important;
	color: #292c9b !important;
	font-weight: 600;
}

#CybotCookiebotDialogDetailBodyContentTextAbout,
#CybotCookiebotDialogBodyContentText,
.CybotCookiebotDialogDetailBodyContentCookieTypeIntro {
	font-size: 1rem !important;
	line-height: 1.4rem !important;
}

.CybotExternalLinkArrow {
	display: none !important;
}

#CybotCookiebotDialogDetailBodyContentTextAbout a {
	font-size: inherit !important;
}

#CybotCookiebotDialogBodyLevelButtonCustomize {
	text-transform: uppercase;
	font-size: 16px;
	font-weight: 600;
	
}

#CybotCookiebotDialogPoweredByText {
	display: none !important;
}

#CybotCookiebotDialogFooter #CybotCookiebotDialogBodyLevelButtonCustomize .CybotCookiebotDialogArrow {
	transform: rotate(45deg) scale(0.7) !important;
}

#CybotCookiebotDialogBodyEdgeMoreDetailsLink {
}

#CybotCookiebotDialogNav .CybotCookiebotDialogNavItemLink {
	font-weight: 600 !important;
}

#CybotCookiebotDialog.CybotEdge #CybotCookiebotDialogBodyEdgeMoreDetails a {
	font-weight: inherit !important;
}

#CybotCookiebotDialog.CybotEdge #CybotCookiebotDialogBodyEdgeMoreDetails a:after {
	display: none !important;
}

#CybotCookiebotDialogHeader {
	display: none !important;
}

.CybotCookiebotDialogBodyBottomWrapper {
	display: none !important;
}

#CybotCookiebotDialog h2 {
	font-weight: 600 !important;
}

#CybotCookiebotDialogNav .CybotCookiebotDialogNavItem {
	font-size: 0.2rem !important;
	text-transform: uppercase !important;
	line-height: 1.5em !important;
	color: #292c9b !important;
}

#CybotCookiebotDialogNav .CybotCookiebotDialogNavItem a {
	font-size: 0.8rem !important;
}

#CybotCookiebotDialog .CookieCard .CybotCookiebotDialogDetailBodyContentCookieTypeIntro, #CybotCookiebotDialogDetailBodyContentCookieContainerTypes .CybotCookiebotDialogDetailBodyContentCookieTypeTableContainer, #CybotCookiebotDialogDetailBodyContentIABv2Tabs .CollapseCard {
	padding-top: 0 !important;
}

.CybotCookiebotDialogBodyLevelButtonSliderWrapper {
	transform: scale(0.8) !important;
}

@media screen and (min-width: 1280px) {
	#CybotCookiebotDialog {
		padding: 24px 24px !important;
	}
	
	#CybotCookiebotDialog.CybotEdge .CybotCookiebotDialogBodyBottomWrapper {
		margin-top: 0 !important;
	}
}

@media screen and (max-width: 1280px) {
	#CybotCookiebotDialog  {
		top: auto !important;
		bottom: 0 !important;
		transform: translate(-50%,-10px) !important;
	}
	
	#CybotCookiebotDialogBodyContent {
		padding: 24px !important;
	}
	
	#CybotCookiebotDialogBodyContentTitle {
		font-size: 0.8rem !important;
		line-height: 1.5em !important;
	}
	
	#CybotCookiebotDialogDetailBodyContentTextAbout,
	#CybotCookiebotDialogBodyContentText,
	.CybotCookiebotDialogDetailBodyContentCookieTypeIntro {
		font-size: 0.8rem !important;
		line-height: 1.1rem !important;
	}	
	
}

@media screen and (min-width: 1280px) {
	#CybotCookiebotDialog {
		min-height: 165px;
	}
}

.tt-heading.secondary-font h1, .tt-heading.secondary-font h2 {
	font-family: shantell-sans-normal, sans-serif;
	font-weight: 500;
	letter-spacing: -0.05em;
	line-height: 1.1em!important;
	
}

h1.secondary-font, h2.secondary-font {
	font-family: shantell-sans-normal, sans-serif;
	font-weight: 500;
	letter-spacing: -0.05em;
	line-height: 1.1em!important;
	
}

.CookiebotWidget-main-logo,
#CybotCookiebotDialogDetailFooter {
	display: none !important;
}

#CookiebotWidget .CookiebotWidget-consent-details button {
	color: #292c9b !important;
	font-weight: 600 !important;
}

#CookiebotWidget .CookiebotWidget-body .CookiebotWidget-consents-list li.CookiebotWidget-approved svg {
	fill: #292c9b !important;
}

#CookiebotWidget.CookiebotWidget-open #CookiebotWidget-widgetContent,
#CookiebotWidget.CookiebotWidget-open {
	border-radius: 0 !important;
}

#CookiebotWidget #CookiebotWidget-buttons button {
	font-size: 0.75rem !important;
	border-radius: 5px !important;
	border-width: 1px !important;
	text-transform: uppercase !important;
	font-weight: 600 !important;
}

#CookiebotWidget strong {
	font-weight: 600 !important;
	font-size: 1rem !important;
	line-height: 1.5em !important;
	color: #292c9b !important;	
}

#CookiebotWidget .CookiebotWidget-consent-details .CookiebotWidget-consent-details-box {
	border-radius: 0 !important;
}

#CookiebotWidget strong.CookiebotWidget-state {
	font-size: 0.75rem !important;
}

/* / Cookiebot */


/* specs taulukko */

.spec-table {
  width: 100%;
  margin: 0 auto;
  border-collapse: collapse;
  font-size: 16px;
  line-height: 1.5;
}

.spec-table th,
.spec-table td {
  padding: 10px 12px;
  border-bottom: 1px solid #ddd;
  text-align: left;
  vertical-align: top;
}

.spec-table th {
  background-color: #f4f4f4;
  width: 40%;
  font-weight: 600;
}

@media (max-width: 600px) {
  .spec-table th,
  .spec-table td {
    display: block;
    width: 100%;
    padding: 8px 0;
  }

  .spec-table th {
    background-color: transparent;
    font-weight: bold;
    padding-top: 16px;
  }

  .spec-table tr {
    margin-bottom: 10px;
    display: block;
  }
}


/* Estetään taustaskrollaus popupin ollessa auki */
html.popup-open,
body.popup-open {
	overflow: hidden !important;
	height: 100%;
	position: fixed;
	width: 100%;
}

/* Overlay täyttää koko näkymän ja keskittää sisällön */
#popup-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0, 0, 0, 0.8);
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 99999;
}

/* Popupin sisältö – keskitetty, tyylitelty laatikko */
#popup-content {
	background: #fff;
	padding: 40px;
	width: 90%;
	max-width: 600px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
	border-radius: 10px;
	position: relative;
	z-index: 100000;
}

/* Sulkupainike */
.close-popup {
	position: absolute;
	top: 10px;
	right: 15px;
	font-size: 24px;
	color: #333;
	text-decoration: none;
	cursor: pointer;
	z-index: 100001;
}

/* Poistaa sinisen korostuksen kaikista elementeistä */
* {
	-webkit-tap-highlight-color: transparent;
}

/* Fiksaa tekstikenttien marginaalit, jos p -elementin jälkeen on heti listaelementti */

.tt-section.columns .text-content p+ul,
.tt-section.columns .text-content p+ol {
	margin-top: 0 !important;
}

.tt-section.columns .text-content p:has(+ ul),
.tt-section.columns .text-content p:has(+ ol) {
	margin-bottom: 15px !important;
}

#nf-field-215-container,
#nf-field-216-container,
#nf-field-183-container {
	margin-bottom: 0 !important;
}

/* Tuotesivun (single) karuselli */

.tt-gallery-main {
	position: relative;
	user-select: none;
}

.tt-gallery-main a {
	cursor: zoom-in;
}

.tt-gallery-main .swiper-slide {
    display: flex;
    justify-content: center;
}

.tt-gallery-main .swiper-slide img {
    max-width: 90% !important;
	max-height: 510px;
    display: block !important;
    margin: 0 auto !important;
}

.tt-nav-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	font-size: 24px;
	font-weight: bold;
	color: #652d90;
	background-color: #fff;
	border-radius: 10px;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 10;
	opacity: 0.3;
	transition: opacity 350ms ease;
	user-select: none;
}

.tt-nav-arrow:active {
	opacity: 1;
}

@media (hover: hover) and (pointer: fine) {
	.tt-nav-arrow:hover {
		opacity: 1;
	}
}

.tt-nav-arrow:focus {
	outline: none;
}

.tt-nav-arrow.swiper-button-disabled {
	opacity: 0.15;
	cursor: default;
}

.tt-gallery-prev {
	left: 10px;
}

.tt-gallery-next {
	right: 10px;
}

.tt-gallery-thumbs {
	user-select: none;
	margin-top: 60px;
}

.tt-gallery-thumbs .swiper-slide {
	cursor: pointer;
	padding: 5px;
}


.tt-thumb-square {
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 2px solid transparent;
}

.tt-thumb-square img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(0.85);
	transform-origin: center;
	display: block;

}




.tt-gallery-thumbs .swiper-slide-thumb-active .tt-thumb-square  {
	border: 2px solid #652d90;
	opacity: 1;
	border-radius: 10px;
}

.product-carousel .bli-image,
.product-list-img {
	aspect-ratio: 1 / 1;
	display: flex;
	justify-content: center;
	align-items: center;
}

.product-carousel .bli-image img {
	width: 90%;
}

.product-carousel .bli-image {
	border-radius: 0 !important;
}

.product-list-img {
	overflow: hidden;
	position: relative;
	
}

.product-list-img img {
	width: 90%;
	/*object-fit: cover;*/
	display: block;
}