@charset "UTF-8";
/*!
Theme Name: The freshman studio
Theme URI: https://www.freshman.ch
Author: Elija Zaugg
Author URI: https://www.freshman.ch
Description: ©freshman 2026, another Buddies collective, connecting friends and business, following passions as a collective and working on fulfilling life dreams.
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: The Freshman studio
Tags: Webagentur St. Gallen, Grafikagentur St. Gallen, Design Agentur, eCommerce Agentur
*/
/*--------------------------------------------------------------
>>> Imports:
--------------------------------------------------------------*/
/*--------------------------------------------------------------
>>> Variables:
--------------------------------------------------------------*/
@import url("https://use.typekit.net/tiw3qvn.css");
@import url("https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
:root {
	--spacebody-lg: 70px;
	--dharma-primary: 50px;
	--h1-title: 140px;
	--h2-title: 88px;
	--h3-title: 45px;
	--h5-title: 24px;
	--body-text: 18px;
	--body-text-line-height: 20px;
	--table-text: 65px;
}

@media (max-width: 1299.98px) {
	:root {
		--spacebody-lg: 50px;
		--h1-title: 105px;
		--h3-title: 40px;
		--table-text: 60px;
	}
}

@media (max-width: 991.98px) {
	:root {
		--h1-title: 80px;
		--h2-title: 65px;
		--h3-title: 34px;
	}
}

@media (max-width: 767.98px) {
	:root {
		--spacebody-lg: 30px;
		--h1-title: 10vw;
		--h2-title: 50px;
		--h3-title: 28px;
	}
}

@media (max-width: 575.98px) {
	:root {
		--spacebody-lg: 20px;
		--dharma-primary: 40px;
		--h2-title: 9vw;
		--h3-title: 24px;
		--h5-title: 20px;
		--table-text: 50px;
		--body-text: 14px;
		--body-text-line-height: 14px;
	}
}

/*--------------------------------------------------------------
>>> Navigation (Black Agency Overlay & Clean Hover)
--------------------------------------------------------------*/
/* Basics */
.site-header {
	position: relative;
	width: 100%;
	top: 0;
	z-index: 999;
	background: #202020;
	color: #FFFFFF;
}

.header-inner {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	gap: 12px;
	padding: 30px var(--spacebody-lg);
	min-height: 78px;
}

.menu-toggle,
.menu-close,
.header-col--left p a,
.overlay-menu__bar-left {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: var(--dharma-primary);
	font-style: italic;
	font-weight: 800;
	letter-spacing: 0;
	transition: all .2s ease-in-out;
}

.menu-toggle:hover,
.menu-close:hover,
.header-col--left p a:hover,
.overlay-menu__bar-left:hover {
	opacity: 0.25;
}

/* Spalten */
.header-col--left {
	display: none;
}

.header-col--center {
	justify-self: start;
}

.header-col--right {
	justify-self: end;
}

/* Logo */
.header-logo {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
}

.custom-logo {
	display: block;
	height: auto;
	width: 200px;
	position: relative;
	top: -16px;
}

/* Toggle */
.menu-toggle,
.menu-close {
	background: transparent;
	border: 0;
	color: #FFFFFF;
	cursor: pointer;
	padding: 0;
	text-transform: uppercase;
}

.menu-toggle:focus, .menu-toggle:focus-within, .menu-toggle:focus-visible, .menu-close:focus, .menu-close:focus-within, .menu-close:focus-visible {
	outline: none;
}

.header-widget {
	font-style: italic;
	font-weight: 800;
	text-transform: uppercase;
	white-space: nowrap;
}

/* ===== Overlay Menu (Black & Fresh) ===== */
.overlay-menu {
	position: fixed;
	inset: 0;
	background: #202020;
	color: #FFFFFF;
	font-family: "dharma-gothic-c", sans-serif;
	z-index: 2000;
	opacity: 0;
	pointer-events: none;
	display: flex;
	flex-direction: column;
	transform: scale(1.05);
	transition: opacity 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
	overflow-y: auto;
	overflow-x: hidden;
}

.overlay-menu #menu-header-navigation {
	font-family: "Base Neue", sans-serif;
}

.overlay-menu.is-open {
	opacity: 1;
	pointer-events: auto;
	transform: scale(1);
}

.overlay-menu.is-open .overlay-menu__list > li {
	opacity: 1;
	transform: translateX(0);
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(1) {
	transition-delay: 0.18s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(2) {
	transition-delay: 0.26s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(3) {
	transition-delay: 0.34s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(4) {
	transition-delay: 0.42s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(5) {
	transition-delay: 0.5s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(6) {
	transition-delay: 0.58s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(7) {
	transition-delay: 0.66s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(8) {
	transition-delay: 0.74s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(9) {
	transition-delay: 0.82s;
}

.overlay-menu.is-open .overlay-menu__list > li:nth-child(10) {
	transition-delay: 0.9s;
}

/* obere Bar im Overlay */
.overlay-menu__bar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 18px 22px;
	min-height: 78px;
	flex-shrink: 0;
}

.overlay-menu__bar-left {
	display: flex;
	align-items: center;
	gap: 12px;
}

/* Navigation groß */
.overlay-menu__nav {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	padding: 40px 22px;
	flex-grow: 1;
}

.overlay-menu__nav::before, .overlay-menu__nav::after {
	content: '';
	flex: 1 1 auto;
}

.overlay-menu__list {
	list-style: none;
	margin: auto 0;
	padding: 20px 0;
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 15px;
	width: 100%;
}

.overlay-menu__list > li {
	opacity: 0;
	transform: translateX(100vw);
	transition: all 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
}

/* --- HAUPT-LINKS --- */
.overlay-menu__list > li > a,
.menu-item-wrapper {
	text-decoration: none;
	text-transform: uppercase;
	font-weight: 900;
	letter-spacing: 0;
	font-size: clamp(50px, 8vw, 120px);
	line-height: 0.7;
	transform: skewX(-10deg);
	color: transparent;
	-webkit-text-stroke: 2px rgba(255, 255, 255, 0.4);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	cursor: pointer;
}

.overlay-menu__list > li > a a,
.menu-item-wrapper a {
	color: inherit;
	-webkit-text-stroke: inherit;
	text-decoration: none;
	transition: inherit;
}

.overlay-menu__list > li > a.current-menu-item > a, .overlay-menu__list > li > a.current-menu-item,
.menu-item-wrapper.current-menu-item > a,
.menu-item-wrapper.current-menu-item {
	-webkit-text-stroke: 0;
	color: #FFFFFF;
}

.overlay-menu__list > li > a:hover,
.menu-item-wrapper:hover {
	-webkit-text-stroke: 0px transparent;
	color: #FFFFFF;
}

.overlay-menu__list > li > a:hover a,
.menu-item-wrapper:hover a {
	color: #FFFFFF;
	-webkit-text-stroke: 0px transparent;
}

.overlay-menu__list > li > a:hover .submenu-toggle,
.menu-item-wrapper:hover .submenu-toggle {
	color: #FFFFFF;
}

/* --- DROPDOWN (SUB-MENU) --- */
.submenu-toggle {
	background: transparent;
	border: none;
	color: transparent;
	font-family: sans-serif;
	font-weight: 400;
	font-size: clamp(30px, 5vw, 60px);
	cursor: pointer;
	padding: 0 10px;
	outline: none;
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), color 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.menu-item-has-children.is-expanded .submenu-toggle {
	transform: rotateX(180deg);
	color: #FFFFFF;
}

.sub-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 15px;
	overflow: hidden;
	height: 0;
	opacity: 0;
	transition: height 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.5s ease, margin 0.3s ease;
}

.sub-menu li.current-menu-item > a {
	color: #FFFFFF;
}

.sub-menu li a {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: clamp(35px, 5vw, 55px);
	line-height: 0.8;
	transform: skewX(-10deg);
	-webkit-text-stroke: 0;
	color: rgba(255, 255, 255, 0.5);
	text-transform: uppercase;
	letter-spacing: 0;
	transition: color 0.3s ease;
	display: inline-block;
}

.sub-menu li a:hover {
	color: #E8A7FF;
}

.menu-item-has-children.is-expanded .sub-menu {
	margin-top: 30px;
}

/* Footer links unten */
.overlay-menu__footer {
	display: flex;
	gap: 18px;
	justify-content: center;
	transform: skewX(-10deg);
	font-weight: 700;
	flex-shrink: 0;
	padding-bottom: 30px;
}

.overlay-menu__footer .post-footer-wrapper ul {
	padding-left: 0;
}

.overlay-menu__footer .post-footer-wrapper ul li {
	padding-left: 7.5px;
	padding-right: 7.5px;
	display: inline-block;
	visibility: visible;
}

.overlay-menu__footer .post-footer-wrapper ul li a {
	font-size: var(--dharma-primary);
	text-transform: uppercase;
	opacity: 0.15;
	transition: .2s ease-in-out all;
}

.overlay-menu__footer .post-footer-wrapper ul li a:hover {
	opacity: 1;
	color: #E8A7FF;
}

.overlay-menu__footer a {
	color: #FFFFFF;
	text-decoration: none;
}

body.menu-open {
	overflow: hidden;
}

/* Responsive */
@media (min-width: 900px) {
	.header-inner {
		grid-template-columns: 1fr auto 1fr;
	}
	.header-col--left {
		display: block;
		justify-self: start;
	}
	.header-col--center {
		justify-self: center;
	}
}

@media (max-width: 575.98px) {
	.overlay-menu__bar-left p {
		margin-bottom: 0;
	}
	.custom-logo {
		width: 150px;
	}
	.overlay-menu__list > li > a,
	.menu-item-wrapper {
		-webkit-text-stroke: 1.5px rgba(255, 255, 255, 0.4);
	}
}

/*--------------------------------------------------------------
>>> Footer:
--------------------------------------------------------------*/
footer {
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
}

footer .post-footer-wrapper {
	margin-bottom: 30px;
}

footer .post-footer-wrapper .menu-footer-menue-container {
	font-family: "dharma-gothic-c", sans-serif;
	text-transform: uppercase;
	font-size: var(--dharma-primary);
	transform: skewX(-10deg);
	text-align: center;
}

footer .post-footer-wrapper .menu-footer-menue-container ul {
	padding-left: 0;
}

footer .post-footer-wrapper .menu-footer-menue-container ul li {
	list-style-type: none;
	display: inline-block;
	padding-right: 5px;
	padding-left: 5px;
}

footer .post-footer-wrapper .menu-footer-menue-container ul li a {
	opacity: 0.15;
	transition: opacity .2s ease-in;
}

footer .post-footer-wrapper .menu-footer-menue-container ul li a:hover {
	opacity: 1;
}

/* Footer Contact Form 7 */
footer .wpcf7 {
	display: flex;
	justify-content: center;
	margin-bottom: 85px;
	margin-top: 0;
}

footer .wpcf7-form {
	width: 370px;
	max-width: 100%;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 13px 7px 0px;
	border-bottom: 1px solid #FFFFFF;
	margin: 0 auto;
	position: relative;
	/* Email Input */
	/* Send Button */
	/* Spinner */
	/* Response Message unterhalb */
}

footer .wpcf7-form .wpcf7-form-control-wrap {
	flex: 1;
	min-width: 0;
}

footer .wpcf7-form .cf7-email {
	width: 100%;
	background: transparent;
	border: 0;
	outline: none;
	box-shadow: none;
	padding: 0;
	margin: 0;
	font-family: "dharma-gothic-c", sans-serif;
	font-size: var(--dharma-primary);
	transform: skewX(-8deg);
	text-transform: uppercase;
	font-weight: 300;
	line-height: 1;
	letter-spacing: 0.2px;
	color: #FFFFFF;
}

footer .wpcf7-form .cf7-email::placeholder {
	color: #FFFFFF;
	opacity: 1;
}

footer .wpcf7-form .cf7-email:-webkit-autofill {
	-webkit-text-fill-color: #FFFFFF;
	transition: background-color 9999s ease-in-out 0s;
	box-shadow: 0 0 0 1000px transparent inset;
}

footer .wpcf7-form .cf7-send {
	background: transparent;
	border: 0;
	padding: 0;
	margin: 0;
	cursor: pointer;
	appearance: none;
	font-size: var(--dharma-primary);
	font-family: "dharma-gothic-c", sans-serif;
	transform: skewX(-8deg);
	font-weight: 300;
	line-height: 1;
	text-transform: uppercase;
	color: #FFFFFF;
	opacity: 0.13;
	transition: opacity 0.2s ease;
}

footer .wpcf7-form .cf7-send:hover {
	opacity: 1;
}

footer .wpcf7-form .wpcf7-spinner {
	margin-left: 8px;
	align-self: center;
	position: absolute;
	right: 0;
}

footer .wpcf7-form .wpcf7-response-output {
	flex-basis: 100%;
	margin: 8px 0 0;
	padding: 0;
	border: 0;
	font-size: 12px;
	color: #FFFFFF;
	position: absolute;
	bottom: -45px;
	font-family: 'Barlow', sans-serif;
	color: #E8A7FF;
}

/* Der Footer: Fixiert im Hintergrund */
#footer {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 0;
	/* Hinter dem Main Content */
	visibility: visible;
	will-change: transform;
}

/* Der Hauptinhalt: Scrollt darüber */
#primary {
	position: relative;
	z-index: 10;
	/* Über dem Footer */
	background-color: #202020;
	/* WICHTIG: Muss eine Hintergrundfarbe haben, sonst sieht man den Footer durch */
	width: 100%;
	/* Für die Animation */
	transform-origin: center bottom;
	/* Skaliert von unten mittig */
	will-change: transform, border-radius;
	/* Sagt dem Browser, dass sich das ändern wird */
	/* Schatten für bessere Tiefenwirkung (wie bei ESE) */
	box-shadow: 0 40px 55px #131313;
}

/* Optional: Die Footer Inhalte sollten erst sichtbar sein, wenn man unten ist (Performance) */
.footer-wrapper {
	width: 100%;
}

/* Ergänzung im SCSS */
.wp-block-columns:last-of-type {
	overflow: hidden;
	/* Zwingend notwendig für Border-Radius */
	/* Optional: Falls der Block keine eigene Hintergrundfarbe hat, hier setzen: */
	/* background-color: #ffffff; */
}

/*--------------------------------------------------------------
>>> Home Page: Cursiv Studio (Ultimate Final Layout)
--------------------------------------------------------------*/
.ani-fade-up-element {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
	will-change: opacity, transform;
}

.ani-fade-up-element.ani-appear {
	opacity: 1;
	transform: translateY(0);
}

.home h1 {
	padding-right: var(--spacebody-lg);
	padding-left: var(--spacebody-lg);
	position: relative;
	top: -56px;
	left: -15px;
}

.home .studio-portfolio-wrapper-mobile {
	display: none;
}

.home .studio-portfolio-wrapper-mobile .container {
	padding-left: 0;
	padding-right: 0;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(1) {
	transition-delay: 0.1s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(2) {
	transition-delay: 0.2s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(3) {
	transition-delay: 0.3s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(4) {
	transition-delay: 0.4s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(5) {
	transition-delay: 0.5s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(6) {
	transition-delay: 0.6s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(7) {
	transition-delay: 0.7s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(8) {
	transition-delay: 0.8s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(9) {
	transition-delay: 0.9s;
}

.home .studio-portfolio-wrapper-mobile .pf-item-archiv:nth-child(10) {
	transition-delay: 1s;
}

.home .white-section {
	min-height: 100vh;
	background-color: #FFFFFF !important;
	color: #202020 !important;
	display: flex !important;
	align-items: center;
	padding: 0 !important;
}

.home .white-section > .wp-block-column {
	width: 100% !important;
	max-width: 100% !important;
	flex-basis: 100% !important;
	padding: 5vh var(--spacebody-lg) !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: center !important;
	margin: 0 auto !important;
}

.home .white-section h3 {
	color: #202020 !important;
	margin: 0 0 40px 0;
	text-align: center;
}

.home .white-section .wp-block-group.is-layout-grid {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: clamp(15px, 2vw, 25px) !important;
	margin: 0;
	width: 100% !important;
	max-width: none !important;
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image {
	margin: 0 !important;
	border-radius: 12px;
	box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
	overflow: hidden;
	transform: translateZ(0);
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image:nth-child(1) {
	transition-delay: 0.2s;
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image:nth-child(2) {
	transition-delay: 0.3s;
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image:nth-child(3) {
	transition-delay: 0.4s;
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image:nth-child(4) {
	transition-delay: 0.5s;
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 1/1;
	display: block;
	transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.home .white-section .wp-block-group.is-layout-grid figure.wp-block-image:hover img {
	transform: scale(1.08);
}

.home .white-section .wp-block-table {
	width: 100% !important;
	margin: 0 auto !important;
	display: table !important;
	overflow: visible !important;
	scrollbar-width: none;
}

.home .white-section .wp-block-table table {
	width: 100% !important;
	display: table !important;
}

.home .white-section .wp-block-table table td {
	overflow: visible !important;
	line-height: 1.1 !important;
	padding-top: 10px !important;
	padding-bottom: 10px !important;
}

.home .white-section .wp-block-table table td a {
	color: #202020 !important;
	text-decoration: none;
	transition: opacity 0.3s ease;
}

.home .white-section .wp-block-table table td a:hover {
	opacity: .7;
}

.home .white-section .wp-block-table::-webkit-scrollbar {
	display: none;
}

.home .fm-home-service-grid {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 20px !important;
	margin: 0;
	max-width: 900px;
	overflow: visible !important;
	padding-top: 15px;
	padding-bottom: 15px;
}

.home .fm-home-service-grid::before, .home .fm-home-service-grid::after {
	display: none !important;
}

.home .fm-home-service-grid .fm-home-service-card {
	background-color: #272727;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.05);
	padding: 30px 25px;
	display: flex;
	flex-direction: column;
	margin: 0 !important;
	position: relative;
	overflow: hidden;
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease, border-color 0.4s ease, opacity 0.8s ease;
	transform: translateZ(0);
	min-height: 220px;
	z-index: 1;
	padding-top: 50px !important;
	padding-bottom: 50px !important;
}

.home .fm-home-service-grid .fm-home-service-card:nth-child(1) {
	transition-delay: 0.1s;
}

.home .fm-home-service-grid .fm-home-service-card:nth-child(2) {
	transition-delay: 0.2s;
}

.home .fm-home-service-grid .fm-home-service-card:nth-child(3) {
	transition-delay: 0.3s;
}

.home .fm-home-service-grid .fm-home-service-card:nth-child(4) {
	transition-delay: 0.4s;
}

.home .fm-home-service-grid .fm-home-service-card::before {
	content: '';
	position: absolute;
	inset: -50%;
	background: radial-gradient(circle at 50% 0%, rgba(232, 167, 255, 0.15) 0%, transparent 60%);
	opacity: 0;
	transition: opacity 0.6s ease;
	pointer-events: none;
	z-index: 1;
}

.home .fm-home-service-grid .fm-home-service-card > * {
	position: relative;
	z-index: 2;
}

.home .fm-home-service-grid .fm-home-service-card p:first-of-type {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 50px;
	color: #E8A7FF;
	margin: 0 0 15px 0 !important;
	line-height: 1;
	transform: skewX(-10deg);
	display: block;
}

.home .fm-home-service-grid .fm-home-service-card h3 {
	font-family: "Base Neue", sans-serif;
	font-size: clamp(30px, 2vw, 26px);
	text-transform: uppercase;
	margin: 0 0 10px 0 !important;
	color: #FFFFFF;
	line-height: 0.9;
}

.home .fm-home-service-grid .fm-home-service-card p:nth-of-type(2) {
	font-family: 'Montserrat', sans-serif;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.4;
	margin-bottom: 20px !important;
	flex-grow: 1;
}

.home .fm-home-service-grid .fm-home-service-card ul.fm-tags {
	list-style: none;
	padding: 0;
	margin: 0 0 20px 0 !important;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.home .fm-home-service-grid .fm-home-service-card ul.fm-tags li {
	font-family: "Base Neue", sans-serif;
	font-size: 11px;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding: 6px 12px;
	background: rgba(32, 32, 32, 0.3);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 50px;
	color: rgba(255, 255, 255, 0.8);
	transition: all 0.3s ease;
	margin: 0;
}

.home .fm-home-service-grid .fm-home-service-card p:last-of-type {
	margin: auto 0 0 0 !important;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 15px;
}

.home .fm-home-service-grid .fm-home-service-card p:last-of-type a {
	font-family: "Base Neue", sans-serif;
	font-size: 16px;
	color: #FFFFFF;
	text-transform: uppercase;
	text-decoration: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.home .fm-home-service-grid .fm-home-service-card p:last-of-type a::before {
	content: '';
	position: absolute;
	inset: -50px;
	z-index: 10;
}

.home .fm-home-service-grid .fm-home-service-card p:last-of-type a::after {
	content: '\2192';
	transition: transform 0.3s ease;
	color: rgba(255, 255, 255, 0.3);
	font-family: sans-serif;
	font-size: 20px;
	position: relative;
	top: -2px;
	line-height: 1;
}

.home .fm-home-service-grid .fm-home-service-card:hover {
	transform: translateY(-8px);
	border-color: rgba(232, 167, 255, 0.4);
	box-shadow: 0 15px 30px rgba(0, 0, 0, 0.5), 0 0 20px rgba(232, 167, 255, 0.15);
	z-index: 10;
}

.home .fm-home-service-grid .fm-home-service-card:hover::before {
	opacity: 1;
}

.home .fm-home-service-grid .fm-home-service-card:hover h3 {
	color: #E8A7FF;
}

.home .fm-home-service-grid .fm-home-service-card:hover ul.fm-tags li {
	border-color: rgba(232, 167, 255, 0.4);
	color: #FFFFFF;
}

.home .fm-home-service-grid .fm-home-service-card:hover p:last-of-type a {
	color: #E8A7FF;
}

.home .fm-home-service-grid .fm-home-service-card:hover p:last-of-type a::after {
	transform: translateX(5px);
	color: #E8A7FF;
}

.home .fm-marquee-container {
	width: 100vw !important;
	max-width: 100vw !important;
	position: relative;
	margin-left: calc(50% - 50vw) !important;
	overflow: hidden;
	display: block;
	padding: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	border-bottom: none;
}

.home .fm-marquee-container > div, .home .fm-marquee-container > .wp-block-group__inner-container, .home .fm-marquee-container .fm-marquee-track {
	display: flex !important;
	flex-wrap: nowrap !important;
	width: max-content !important;
	gap: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	animation: fmMarqueeHome 80s linear infinite;
}

.home .fm-marquee-container > div:hover, .home .fm-marquee-container > .wp-block-group__inner-container:hover, .home .fm-marquee-container .fm-marquee-track:hover {
	animation-play-state: paused;
}

.home .fm-marquee-container ul {
	display: flex !important;
	align-items: center;
	flex-shrink: 0 !important;
	list-style: none !important;
	margin: 0 !important;
	padding: 0 !important;
	gap: 0 !important;
}

.home .fm-marquee-container ul li {
	display: inline-flex !important;
	align-items: center;
	padding: 0 !important;
	margin: 0 !important;
	font-family: "Base Neue", sans-serif;
	font-size: clamp(40px, 7vw, 80px);
	line-height: 1.2;
	text-transform: uppercase;
	color: transparent;
	-webkit-text-stroke: 1px rgba(255, 255, 255, 0.15);
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	white-space: nowrap;
	cursor: default;
}

.home .fm-marquee-container ul li:hover {
	color: #FFFFFF;
	-webkit-text-stroke: 1px #FFFFFF;
	transform: skewX(-10deg);
}

.home .fm-marquee-container ul li::after {
	content: '—';
	color: inherit;
	-webkit-text-stroke: inherit;
	opacity: 0.6;
	margin-left: 80px !important;
	margin-right: 80px !important;
}

@keyframes fmMarqueeHome {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}

.home .wp-block-columns:not(.white-section) .wp-block-column, .page-id-603 .wp-block-columns:not(.white-section) .wp-block-column {
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
	padding-bottom: 100px;
	padding-top: 100px;
}

.home :where(.wp-block-columns), .page-id-603 :where(.wp-block-columns) {
	margin-bottom: 0;
}

.home .wp-block-columns-1 .wp-block-column, .page-id-603 .wp-block-columns-1 .wp-block-column {
	display: flex;
	justify-content: center;
	align-items: center;
}

.home .wp-block-columns-2 .wp-block-column, .page-id-603 .wp-block-columns-2 .wp-block-column {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}

.home .page-standard > .wp-block-columns:last-of-type, .page-id-603 .page-standard > .wp-block-columns:last-of-type {
	border-bottom-left-radius: 20px;
	border-bottom-right-radius: 20px;
	overflow: hidden;
	transform: translateZ(0);
}

.wp-block-table {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: var(--table-text);
	font-style: italic;
	display: table !important;
	overflow: visible !important;
}

.wp-block-table table {
	overflow: visible !important;
}

.wp-block-table table td {
	border: none;
	padding: 15px 3px;
	text-transform: uppercase;
	overflow: visible !important;
	line-height: 1.3 !important;
}

.wp-block-table table td:nth-child(2) {
	opacity: 0.13;
}

.wp-block-table table tr:hover td {
	transition: opacity .15s ease-in-out;
}

/*--------------------------------------------------------------
>>> Mobile version
--------------------------------------------------------------*/
@media (max-width: 1299.98px) {
	.home .studio-slider {
		display: none !important;
	}
	.home .studio-portfolio-wrapper-mobile {
		display: block;
	}
	.home h1 {
		top: -42px;
		left: 0;
		z-index: -9;
	}
}

@media (max-width: 991.98px) {
	.home .white-section .wp-block-group.is-layout-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 767.98px) {
	.home .fm-home-service-grid {
		grid-template-columns: 1fr !important;
		width: 100% !important;
		max-width: 100% !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}
	.home .fm-home-service-grid .fm-home-service-card p:first-of-type {
		margin-bottom: 38px  !important;
	}
	.home .white-section .wp-block-group.is-layout-grid {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 15px !important;
	}
	.home .fm-marquee-container ul li::after {
		margin-left: 40px !important;
		margin-right: 40px !important;
	}
}

/*--------------------------------------------------------------
>>> Cursiv Studio Portfolio: (No Overlay Glow & H1 Priority)
--------------------------------------------------------------*/
.page-id-603 h2 {
	margin-top: 50px;
}

/*--------------------------------------------------------------
>>> Work Page: White Section Fix (100vh & Centering)
--------------------------------------------------------------*/
.page-id-603 .white-section {
	min-height: 100vh;
	background-color: #FFFFFF !important;
	color: #202020 !important;
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: center !important;
	padding: 10vh var(--spacebody-lg) !important;
	text-align: center;
}

.page-id-603 .white-section > .wp-block-column {
	display: flex !important;
	flex-direction: column !important;
	justify-content: center !important;
	align-items: center !important;
	width: 100%;
}

.page-id-603 .white-section h3 {
	color: #202020 !important;
	margin: 0;
}

.studio-portfolio-wrapper {
	position: relative;
	overflow: hidden;
	padding-top: 0;
	padding-bottom: 30px;
}

.studio-portfolio-wrapper .container {
	max-width: 100%;
}

.studio-portfolio-wrapper .studio-portfolio {
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(1),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(1) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(2),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(2) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(3),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(3) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(4),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(4) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(5),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(5) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(6),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(6) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(7),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(7) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(8),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(8) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(9),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(9) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(10),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(10) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(11),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(11) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(12),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(12) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(13),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(13) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(14),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(14) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(15),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(15) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(16),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(16) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(17),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(17) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(18),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(18) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(19),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(19) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(20),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(20) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(21),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(21) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(22),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(22) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(23),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(23) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(24),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(24) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(25),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(25) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(26),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(26) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(27),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(27) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(28),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(28) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(29),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(29) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(30),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(30) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(31),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(31) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(32),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(32) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(33),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(33) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(34),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(34) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(35),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(35) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(36),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(36) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(37),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(37) {
	transition-delay: 0.3s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(38),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(38) {
	transition-delay: 0.45s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(39),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(39) {
	transition-delay: 0.6s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(40),
.studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(40) {
	transition-delay: 0.75s;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item, .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv {
	padding-right: 5px;
	padding-left: 5px;
	margin-bottom: 5px;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item .zoom-effect-container, .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv .zoom-effect-container {
	float: left;
	position: relative;
	margin: 0 auto 5px;
	overflow: hidden;
	border-radius: 10px;
	z-index: 9;
	background-color: #202020;
	box-shadow: 0 20px 35px rgba(0, 0, 0, 0.6);
	transform: translateZ(0);
	transition: transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.5s ease;
}

.studio-portfolio-wrapper .studio-portfolio .pf-item .zoom-effect-container img, .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv .zoom-effect-container img {
	width: 100%;
	border-radius: 10px;
	display: block;
	position: relative;
	z-index: 1;
	transition: transform 1.2s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.studio-portfolio-wrapper .studio-portfolio .pf-item .zoom-effect-container:hover, .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv .zoom-effect-container:hover {
	text-decoration: none;
	transform: translateY(-8px);
	box-shadow: 0 30px 50px rgba(0, 0, 0, 0.8), 0 0 40px rgba(232, 167, 255, 0.25);
}

.studio-portfolio-wrapper .studio-portfolio .pf-item .zoom-effect-container:hover img, .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv .zoom-effect-container:hover img {
	transform: scale(1.08);
}

.studio-portfolio-post-page {
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
	padding-bottom: 100px;
}

.studio-portfolio-post-page .wp-block-columns {
	min-height: auto;
}

.studio-portfolio-post-page .wp-block-columns .wp-block-column {
	display: block;
	padding-left: 0;
	padding-right: 0;
}

.studio-portfolio-post-page h2 {
	padding-top: 50px;
	padding-bottom: 50px;
}

.studio-portfolio-post-page a {
	font-weight: 700;
	position: relative;
}

.studio-portfolio-post-page a:after, .studio-portfolio-post-page a::before {
	content: "";
	width: 100%;
	border-bottom: 1px solid #FFFFFF;
	position: absolute;
	bottom: 0;
	left: 0;
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.4s;
	transform-origin: right;
	opacity: 1;
}

.studio-portfolio-post-page a:after {
	opacity: 0;
	transform: scale(0);
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) 0.2s, opacity 0.4s 0.2s;
	transform-origin: left;
}

.studio-portfolio-post-page a:hover:before {
	opacity: 0;
	transform: scale(0);
}

.studio-portfolio-post-page a:hover:after {
	opacity: 1;
	transform: scale(1);
}

.studio-portfolio-post-page a:hover {
	text-decoration: none;
	color: #FFFFFF;
}

.studio-portfolio-post-page p {
	font-size: 18px;
	line-height: 20px;
}

.studio-portfolio-post-page .wp-block-image {
	margin-bottom: 0;
}

.studio-portfolio-post-page .wp-block-columns:where(.wp-block-columns.is-layout-flex) {
	gap: 0;
}

.studio-portfolio-post-page .wp-block-columns {
	padding-bottom: 50px;
}

.studio-portfolio-post-page .wp-block-columns .wp-block-column {
	padding-top: 0;
	padding-bottom: 0;
}

.studio-portfolio-post-page .pf-project-nav {
	margin-top: 0;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item, .studio-portfolio-post-page .pf-project-nav .pf-prev-item {
	display: inline-block;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item a, .studio-portfolio-post-page .pf-project-nav .pf-prev-item a {
	font-family: "dharma-gothic-c", sans-serif;
	font-weight: 900;
	opacity: .13;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item a:hover, .studio-portfolio-post-page .pf-project-nav .pf-prev-item a:hover {
	opacity: 1;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item {
	right: 0;
	justify-content: end;
	display: flex;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item a {
	text-align: right;
	opacity: 1;
}

.studio-portfolio-post-page .pf-project-nav .pf-next-item a:hover {
	opacity: 0.13;
}

@media (max-width: 1299.98px) {
	.studio-portfolio-wrapper-mobile, .studio-portfolio-wrapper {
		padding-top: 0;
	}
}

@media (max-width: 991.98px) {
	.studio-portfolio-wrapper-mobile .studio-portfolio .pf-item:nth-child(odd), .studio-portfolio-wrapper-mobile .studio-portfolio .pf-item-archiv:nth-child(odd), .studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(odd), .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(odd) {
		padding-left: 0;
	}
	.studio-portfolio-wrapper-mobile .studio-portfolio .pf-item:nth-child(even), .studio-portfolio-wrapper-mobile .studio-portfolio .pf-item-archiv:nth-child(even), .studio-portfolio-wrapper .studio-portfolio .pf-item:nth-child(even), .studio-portfolio-wrapper .studio-portfolio .pf-item-archiv:nth-child(even) {
		padding-right: 0;
	}
}

@media (max-width: 575.98px) {
	.studio-portfolio-wrapper-mobile {
		padding-left: 0;
		padding-right: 0;
	}
	.studio-portfolio-wrapper-mobile .le-portfolio-archiv .pf-item-archiv:nth-child(1n) {
		padding-right: 5px;
		padding-left: var(--spacebody-lg);
		margin-bottom: 5px;
	}
	.studio-portfolio-wrapper-mobile .le-portfolio-archiv .pf-item-archiv:nth-child(2n) {
		padding-right: var(--spacebody-lg);
		padding-left: 5px;
		margin-bottom: 5px;
	}
	.wp-block-spacer {
		height: 37px !important;
	}
}

/*--------------------------------------------------------------
>>> About Page: The Crew (Glitch-Free Master Version)
--------------------------------------------------------------*/
@keyframes cardFadeUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.fm-about-template {
	background-color: #202020;
	color: #FFFFFF;
	padding-bottom: 120px;
}

.fm-about-template .w-60 {
	max-width: 50% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	margin-top: 15px;
	width: 100%;
	text-align: center;
}

.fm-about-template .wp-block-columns.fm-crew-grid {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 40px !important;
	max-width: 1300px;
	margin: 40px auto 40px !important;
	padding: 0 var(--spacebody-lg);
	overflow: visible !important;
	position: relative;
	z-index: 1;
}

.fm-about-template .wp-block-columns.fm-crew-grid::before, .fm-about-template .wp-block-columns.fm-crew-grid::after {
	display: none !important;
}

.fm-about-template .wp-block-column {
	position: relative;
	background: #272727;
	border-radius: 12px;
	border: 1px solid rgba(255, 255, 255, 0.05);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	margin: 0 !important;
	transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.fm-about-template .wp-block-column:hover {
	z-index: 10;
}

.fm-about-template .wp-block-column::before {
	content: '';
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle at 50% 0%, rgba(232, 167, 255, 0.15) 0%, transparent 60%);
	opacity: 0;
	transition: opacity 0.6s ease;
	pointer-events: none;
	z-index: 1;
}

.fm-about-template .wp-block-column figure.wp-block-image {
	margin: 0 !important;
	height: 420px;
	overflow: hidden;
	position: relative;
	background-color: #272727;
}

.fm-about-template .wp-block-column figure.wp-block-image img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block;
	transition: transform 1.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	filter: brightness(0.9);
	-webkit-mask-image: linear-gradient(to bottom, black 60%, transparent 98%);
	mask-image: linear-gradient(to bottom, black 60%, transparent 98%);
}

.fm-about-template .wp-block-column .role, .fm-about-template .wp-block-column h3, .fm-about-template .wp-block-column .company, .fm-about-template .wp-block-column .socials {
	position: relative;
	z-index: 3;
	padding-left: 30px;
	padding-right: 30px;
}

.fm-about-template .wp-block-column .role {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 42px;
	color: #E8A7FF;
	text-transform: uppercase;
	transform: skewX(-10deg);
	margin: -50px 0 5px 0 !important;
	line-height: 1;
}

.fm-about-template .wp-block-column h3 {
	font-family: "Base Neue", sans-serif;
	font-size: 38px !important;
	text-transform: uppercase;
	line-height: 0.9;
	margin: 0 0 15px 0 !important;
	color: #FFFFFF;
	transition: color 0.3s ease;
	opacity: 0;
	animation: cardFadeUp 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
	animation-delay: 0.2s;
}

.fm-about-template .wp-block-column .company {
	font-family: 'Montserrat', sans-serif;
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.5;
	margin-bottom: 30px !important;
	flex-grow: 1;
}

.fm-about-template .wp-block-column .company a {
	color: inherit;
	text-decoration: none !important;
	transition: color 0.3s ease;
	display: inline-block;
	position: relative;
	padding-bottom: 4px;
}

.fm-about-template .wp-block-column .company a::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 1px;
	background-color: #FFFFFF;
	transition: width 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.fm-about-template .wp-block-column .company a[href^="http"]::after {
	content: '\2192';
	display: inline-block;
	margin-left: 6px;
	font-size: 14px;
	transform: rotate(-45deg);
}

.fm-about-template .wp-block-column .company a:hover {
	color: #FFFFFF;
}

.fm-about-template .wp-block-column .company a:hover::before {
	width: 100%;
}

.fm-about-template .wp-block-column .socials {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 20px;
	padding-bottom: 30px;
	display: flex;
	gap: 20px;
	margin-bottom: 0 !important;
}

.fm-about-template .wp-block-column .socials a {
	font-family: "Base Neue", sans-serif;
	font-size: 16px;
	color: rgba(255, 255, 255, 0.4);
	text-decoration: none;
	transition: all 0.3s ease;
}

.fm-about-template .wp-block-column .socials a:hover {
	color: #E8A7FF;
	transform: translateY(-2px);
}

.fm-about-template .wp-block-column:hover {
	transform: translateY(-10px);
	border-color: rgba(232, 167, 255, 0.4);
	box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5), 0 0 40px rgba(232, 167, 255, 0.15);
}

.fm-about-template .wp-block-column:hover::before {
	opacity: 1;
}

.fm-about-template .wp-block-column:hover figure img {
	transform: scale(1.1);
	filter: brightness(1);
}

.fm-about-template .wp-block-column:hover h3 {
	color: #E8A7FF;
}

.fm-about-template .wp-block-column.become-member-card {
	background: linear-gradient(135deg, rgba(232, 167, 255, 0.05) 0%, #202020 100%);
	border: 2px solid rgba(232, 167, 255, 0.1);
	justify-content: center;
	align-items: center;
	text-align: center;
	min-height: 500px;
	transition: all 0.5s ease;
}

.fm-about-template .wp-block-column.become-member-card p a {
	font-family: "Base Neue", sans-serif;
	font-size: 24px;
	color: #FFFFFF;
	text-decoration: none;
	border: 2px solid #FFFFFF;
	padding: 18px 40px 15px;
	border-radius: 8px;
	transition: all 0.3s ease;
	display: inline-block;
}

.fm-about-template .wp-block-column.become-member-card p a:hover {
	background: #FFFFFF;
	color: #202020;
	transform: scale(1.05);
}

.fm-about-template .wp-block-column.become-member-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 0 30px rgba(232, 167, 255, 0.2);
	border-color: rgba(232, 167, 255, 0.6);
}

@media (max-width: 1024px) {
	.fm-about-template .wp-block-columns.fm-crew-grid {
		grid-template-columns: repeat(2, 1fr) !important;
	}
}

@media (max-width: 767.98px) {
	.fm-about-template .wp-block-columns.fm-crew-grid {
		grid-template-columns: 1fr !important;
		gap: 30px !important;
		margin: 30px auto 0px !important;
	}
	.fm-about-template .w-60 {
		max-width: 85% !important;
	}
	.fm-about-template .wp-block-column h3 {
		font-family: "Base Neue", sans-serif;
		font-size: 10vw !important;
		text-transform: uppercase;
		line-height: 0.85;
		margin: 30px 0 -1px 0 !important;
		color: #FFFFFF;
		transition: color 0.3s ease;
		opacity: 0;
		animation: cardFadeUp 1s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
		animation-delay: 0.2s;
	}
}

/*--------------------------------------------------------------
>>> The Freshman Studio - Services (Gutenberg Dynamic)
--------------------------------------------------------------*/
.fm-services-page {
	background-color: #202020;
	color: #FFFFFF;
	padding-top: 10vh;
	padding-bottom: 120px;
	overflow-x: hidden;
}

.fm-services-page .wrapper {
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
	max-width: 1400px;
	margin: 0 auto;
}

.fm-services-page .fm-service-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
}

.fm-services-page .fm-service-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 400px;
	background-color: #272727;
	border-radius: 12px;
	padding: 50px 40px 30px;
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(255, 255, 255, 0.05);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease, border-color 0.4s ease;
	will-change: transform;
}

.fm-services-page .fm-service-card::before {
	content: '';
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle at 50% 0%, rgba(232, 167, 255, 0.15) 0%, transparent 60%);
	opacity: 0;
	transition: opacity 0.6s ease;
	pointer-events: none;
	z-index: 1;
}

.fm-services-page .fm-service-card p.fm-card-number {
	position: absolute;
	top: -20px;
	right: 10px;
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 200px;
	font-weight: 800;
	color: #FFFFFF;
	opacity: 0.03;
	transform: skewX(-10deg);
	transition: all 0.4s ease;
	pointer-events: none;
	line-height: 1;
	z-index: 0;
	margin: 0;
}

.fm-services-page .fm-service-card .fm-card-content {
	position: relative;
	z-index: 2;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.fm-services-page .fm-service-card .fm-card-content h3 {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 60px;
	opacity: 1 !important;
	transform: skewX(-10deg) !important;
	animation: fm-card-slide-up 0.8s ease forwards;
	text-transform: uppercase;
	margin-top: 0;
	margin-bottom: 20px;
	color: #FFFFFF;
	line-height: 1;
	transition: color 0.3s ease;
}

.fm-services-page .fm-service-card .fm-card-content p {
	font-family: 'Montserrat', sans-serif;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.65);
	margin-bottom: 35px;
	max-width: 95%;
}

.fm-services-page .fm-service-card .fm-card-content ul.fm-tags {
	list-style: none;
	padding: 0;
	margin: 0 0 35px 0;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.fm-services-page .fm-service-card .fm-card-content ul.fm-tags li {
	font-family: "Base Neue", sans-serif;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 1px;
	padding: 8px 16px;
	background: rgba(32, 32, 32, 0.3);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 50px;
	color: rgba(255, 255, 255, 0.8);
	transition: all 0.3s ease;
	margin: 0;
}

.fm-services-page .fm-service-card p.fm-card-explore {
	position: relative;
	z-index: 2;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 25px;
	margin-top: auto;
	margin-bottom: 0;
	transition: all 0.3s ease;
}

.fm-services-page .fm-service-card p.fm-card-explore a {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 35px;
	transform: skewX(-10deg);
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
	display: flex;
	justify-content: space-between;
	align-items: center;
	text-decoration: none;
	transition: all 0.3s ease;
	width: 100%;
}

.fm-services-page .fm-service-card p.fm-card-explore a::before {
	content: '';
	position: absolute;
	top: -500px;
	right: -50px;
	bottom: -50px;
	left: -50px;
	z-index: 10;
}

.fm-services-page .fm-service-card p.fm-card-explore a::after {
	content: '\2192';
	display: inline-block;
	font-family: sans-serif;
	font-size: 34px;
	line-height: 1;
	position: relative;
	top: -2px;
	transition: transform 0.3s ease-in-out, color 0.3s ease;
	color: rgba(255, 255, 255, 0.3);
	transform: skewX(10deg);
}

.fm-services-page .fm-service-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 30px 60px rgba(0, 0, 0, 0.6);
	border-color: rgba(232, 167, 255, 0.3);
}

.fm-services-page .fm-service-card:hover::before {
	opacity: 1;
}

.fm-services-page .fm-service-card:hover .fm-card-number {
	opacity: 0.1;
	transform: skewX(-10deg) translateX(-10px);
	color: #E8A7FF;
}

.fm-services-page .fm-service-card:hover .fm-card-content h3 {
	color: #E8A7FF;
}

.fm-services-page .fm-service-card:hover .fm-card-content ul.fm-tags li {
	border-color: rgba(232, 167, 255, 0.4);
	color: #FFFFFF;
}

.fm-services-page .fm-service-card:hover p.fm-card-explore {
	border-color: rgba(232, 167, 255, 0.4);
}

.fm-services-page .fm-service-card:hover p.fm-card-explore a {
	color: #E8A7FF;
}

.fm-services-page .fm-service-card:hover p.fm-card-explore a::after {
	color: #E8A7FF;
	transform: skewX(10deg) translateX(8px);
}

.fm-services-page .fm-services-cta {
	margin-top: 30px;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.fm-services-page .fm-services-cta h2 {
	font-family: "dharma-gothic-c", sans-serif;
	font-size: 110px;
	transform: skewX(-10deg);
	margin-bottom: 30px;
	color: #FFFFFF;
	text-transform: uppercase;
}

.fm-services-page .fm-services-cta .wp-block-buttons {
	display: flex;
	justify-content: center;
	width: 100%;
}

.fm-services-page .fm-services-cta .wp-block-buttons .wp-block-button {
	margin: 0;
	width: 100%;
	max-width: 600px;
}

.fm-services-page .fm-services-cta .wp-block-buttons .wp-block-button .wp-block-button__link {
	display: block !important;
	background-color: transparent !important;
	border: 4px solid #FFFFFF !important;
	color: #FFFFFF !important;
	font-family: "Base Neue", sans-serif !important;
	font-size: 50px !important;
	text-transform: uppercase;
	letter-spacing: 1px;
	border-radius: 8px;
	padding: 48px 80px 43px !important;
	line-height: 1;
	box-shadow: 0 20px 20px rgba(0, 0, 0, 0.16);
	transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
	text-decoration: none;
}

.fm-services-page .fm-services-cta .wp-block-buttons .wp-block-button .wp-block-button__link:hover {
	background-color: #FFFFFF !important;
	color: #202020 !important;
}

@media (max-width: 767.98px) {
	.fm-services-page .fm-services-cta .wp-block-buttons .wp-block-button .wp-block-button__link {
		padding: 25px 80px 17px !important;
		font-size: 33px !important;
	}
}

@media (max-width: 1024px) {
	.fm-services-page .fm-service-grid {
		grid-template-columns: 1fr;
		gap: 30px;
	}
}

@media (max-width: 575.98px) {
	.fm-services-page .fm-services-page {
		padding-top: 5vh;
	}
	.fm-services-page .fm-service-card {
		padding: 40px 25px 25px;
		min-height: auto;
	}
	.fm-services-page .fm-service-card p.fm-card-number {
		font-size: 140px;
	}
	.fm-services-page .fm-service-card .fm-card-content h3 {
		font-size: 45px;
	}
	.fm-services-page .fm-service-card .fm-card-content p {
		font-size: 15px;
		max-width: 100%;
	}
	.fm-services-page .fm-service-card p.fm-card-explore a {
		font-size: 30px;
	}
	.fm-services-page .fm-services-cta h2 {
		font-size: 70px;
	}
}

@keyframes fm-card-slide-up {
	0% {
		top: 40px;
		opacity: 0;
	}
	100% {
		top: 0;
		opacity: 1;
	}
}

/*--------------------------------------------------------------
>>> Service Detail Template (Dynamic Input Widths & Marquee)
--------------------------------------------------------------*/
.fm-service-detail-template {
	background-color: #202020;
	color: #FFFFFF;
	padding-top: 10vh;
	padding-bottom: 120px;
	overflow-x: hidden;
}

.fm-service-detail-template .fm-marquee-container {
	width: 100vw;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	border-bottom: none;
	padding-top: 10px;
	padding-bottom: 10px;
	margin-top: 50px;
	margin-bottom: 50px;
	overflow: hidden;
	display: flex;
}

.fm-service-detail-template .fm-marquee-container .fm-marquee-track {
	display: flex;
	flex-wrap: nowrap;
	width: max-content;
	animation: fmMarquee 40s linear infinite;
}

.fm-service-detail-template .fm-marquee-container .fm-marquee-track:hover {
	animation-play-state: paused;
}

.fm-service-detail-template .fm-marquee-container ul {
	display: flex;
	flex-shrink: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.fm-service-detail-template .fm-marquee-container ul li {
	font-family: "Base Neue", sans-serif;
	font-size: clamp(40px, 7vw, 80px);
	line-height: 1.2;
	text-transform: uppercase;
	color: transparent;
	-webkit-text-stroke: 1px rgba(255, 255, 255, 0.15);
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	white-space: nowrap;
	padding: 0 40px;
	cursor: default;
	margin: 0;
}

.fm-service-detail-template .fm-marquee-container ul li:hover {
	color: #FFFFFF;
	-webkit-text-stroke: 1px #FFFFFF;
	transform: skewX(-10deg);
}

.fm-service-detail-template .fm-marquee-container ul li::after {
	content: '—';
	color: inherit;
	-webkit-text-stroke: inherit;
	margin-left: 80px;
	opacity: 0.6;
}

@keyframes fmMarquee {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}

.fm-service-detail-template div.wpcf7 {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto;
	padding-left: var(--spacebody-lg);
	padding-right: var(--spacebody-lg);
}

.fm-service-detail-template .nl-form-wrapper {
	width: 100%;
}

.fm-service-detail-template .nl-form-wrapper .nl-form-text p {
	display: inline !important;
	margin: 0 !important;
	padding: 0 !important;
}

.fm-service-detail-template .nl-form-wrapper .nl-form-text {
	font-family: "Base Neue", sans-serif;
	font-size: clamp(22px, 3.5vw, 42px);
	text-transform: uppercase;
	font-weight: 900;
	line-height: 1.3;
	color: rgba(255, 255, 255, 0.3);
}

.fm-service-detail-template .nl-form-wrapper .nl-input-wrap,
.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap {
	display: inline-block !important;
	position: relative;
	vertical-align: baseline !important;
	width: auto !important;
}

.fm-service-detail-template .nl-form-wrapper input[type="text"],
.fm-service-detail-template .nl-form-wrapper input[type="email"],
.fm-service-detail-template .nl-form-wrapper select {
	font-family: "Base Neue", sans-serif !important;
	font-size: clamp(22px, 3.5vw, 42px) !important;
	text-transform: uppercase !important;
	color: #E8A7FF !important;
	background: transparent !important;
	border: none !important;
	border-bottom: 3px solid rgba(232, 167, 255, 0.5) !important;
	border-radius: 0 !important;
	padding: 5px 0px  !important;
	height: auto !important;
	line-height: 1;
	field-sizing: content;
	display: inline-block !important;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	outline: none !important;
	box-shadow: none !important;
	cursor: text;
	text-align: center;
	appearance: none;
	-webkit-appearance: none;
	transform: translateY(2px);
}

.fm-service-detail-template .nl-form-wrapper input[type="text"]::placeholder,
.fm-service-detail-template .nl-form-wrapper input[type="email"]::placeholder,
.fm-service-detail-template .nl-form-wrapper select::placeholder {
	color: rgba(232, 167, 255, 0.5) !important;
	text-transform: uppercase !important;
	font-family: "Base Neue", sans-serif !important;
	font-size: inherit !important;
	transition: color 0.3s ease;
}

.fm-service-detail-template .nl-form-wrapper input[type="text"]:focus, .fm-service-detail-template .nl-form-wrapper input[type="text"]:hover, .fm-service-detail-template .nl-form-wrapper input[type="text"]:active,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:focus,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:hover,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:active,
.fm-service-detail-template .nl-form-wrapper select:focus,
.fm-service-detail-template .nl-form-wrapper select:hover,
.fm-service-detail-template .nl-form-wrapper select:active {
	border-bottom: 3px solid #E8A7FF !important;
	background: rgba(232, 167, 255, 0.08) !important;
}

.fm-service-detail-template .nl-form-wrapper input[type="text"]:focus::placeholder, .fm-service-detail-template .nl-form-wrapper input[type="text"]:hover::placeholder, .fm-service-detail-template .nl-form-wrapper input[type="text"]:active::placeholder,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:focus::placeholder,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:hover::placeholder,
.fm-service-detail-template .nl-form-wrapper input[type="email"]:active::placeholder,
.fm-service-detail-template .nl-form-wrapper select:focus::placeholder,
.fm-service-detail-template .nl-form-wrapper select:hover::placeholder,
.fm-service-detail-template .nl-form-wrapper select:active::placeholder {
	color: #E8A7FF !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="your-name"] input {
	width: 10ch !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="company"] input {
	width: 11ch !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="your-email"] input {
	width: 10ch !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="service"] select {
	width: 22ch !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="budget"] select {
	width: 10ch !important;
}

.fm-service-detail-template .nl-form-wrapper select {
	padding-right: 40px !important;
	cursor: pointer;
}

.fm-service-detail-template .nl-form-wrapper select option {
	background-color: #202020;
	color: #FFFFFF;
	font-family: "Base Neue", sans-serif;
	font-size: 20px;
}

.fm-service-detail-template .nl-form-wrapper .nl-select-wrap::after {
	content: '↓';
	font-family: "Base Neue", sans-serif;
	font-size: clamp(26px, 3.5vw, 40px);
	color: #E8A7FF;
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-56%) skewX(10deg);
	pointer-events: none;
	transition: transform 0.3s ease;
}

.fm-service-detail-template .nl-form-wrapper .nl-select-wrap:hover::after {
	transform: translateY(-45%) skewX(10deg) scale(1.1);
}

.fm-service-detail-template .nl-form-wrapper .nl-form-submit {
	margin-top: 80px;
}

.fm-service-detail-template .nl-form-wrapper .nl-form-submit .wpcf7-submit {
	border: 2px solid rgba(255, 255, 255, 0.15) !important;
	background-color: #272727 !important;
	color: #FFFFFF !important;
	font-family: "Base Neue", sans-serif !important;
	font-size: clamp(24px, 4vw, 40px) !important;
	letter-spacing: 2px !important;
	border-radius: 12px !important;
	text-transform: uppercase !important;
	padding: 30px 60px 25px !important;
	width: 100% !important;
	cursor: pointer;
	display: block;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
}

.fm-service-detail-template .nl-form-wrapper .nl-form-submit .wpcf7-submit:hover {
	background-color: #FFFFFF !important;
	color: #202020 !important;
	border-color: #FFFFFF !important;
	transform: translateY(-5px) scale(1.02) !important;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 30px rgba(255, 255, 255, 0.15) !important;
	letter-spacing: 6px !important;
}

.fm-service-detail-template .nl-form-wrapper .nl-form-submit .wpcf7-submit:active {
	transform: translateY(0) scale(0.98) !important;
	box-shadow: none !important;
	letter-spacing: 2px !important;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-not-valid-tip {
	font-family: "Base Neue", sans-serif !important;
	font-size: 14px !important;
	color: #E8A7FF !important;
	position: absolute;
	bottom: -25px;
	left: 50%;
	transform: translateX(-50%);
	text-transform: uppercase;
	white-space: nowrap;
}

.fm-service-detail-template .nl-form-wrapper .wpcf7-response-output {
	border: none !important;
	font-family: "Base Neue", sans-serif !important;
	font-size: 18px !important;
	text-transform: uppercase;
	color: #E8A7FF !important;
	margin-top: 40px !important;
	padding: 0 !important;
}

@media (max-width: 767.98px) {
	.fm-service-detail-template .fm-marquee-container {
		margin-bottom: 50px;
	}
	.fm-service-detail-template .fm-marquee-container ul li {
		padding: 0 20px;
	}
	.fm-service-detail-template .fm-marquee-container ul li::after {
		margin-left: 40px;
	}
	.fm-service-detail-template .nl-form-wrapper .nl-form-text {
		line-height: 1.5;
	}
	.fm-service-detail-template .nl-form-wrapper .nl-input-wrap,
	.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap {
		margin: 4px 0 !important;
		display: inline-block !important;
	}
	.fm-service-detail-template .nl-form-wrapper .wpcf7-form-control-wrap[data-name="service"] select {
		width: 14ch !important;
	}
	.fm-service-detail-template .nl-form-wrapper .nl-form-submit .wpcf7-submit {
		padding: 22px 40px 18px !important;
		font-size: 33px !important;
		margin-top: 40px;
		border-radius: 8px !important;
	}
	.fm-service-detail-template .nl-form-wrapper .nl-form-submit .wpcf7-submit:hover {
		letter-spacing: 4px !important;
	}
}

.fm-audio-player {
	max-width: 900px;
	margin: 60px auto 100px;
	padding: 0 var(--spacebody-lg);
}

.fm-audio-player .track-list {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.fm-audio-player .track-item {
	display: flex;
	align-items: center;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.05);
	border-radius: 8px;
	padding: 15px 25px;
	transition: all 0.3s ease;
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

.fm-audio-player .track-item:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(232, 167, 255, 0.3);
	transform: translateX(5px);
}

.fm-audio-player .track-item.playing {
	background: rgba(232, 167, 255, 0.1);
	border-color: #E8A7FF;
}

.fm-audio-player .track-item.playing .track-title {
	color: #E8A7FF;
}

.fm-audio-player .track-item .play-btn {
	font-size: 24px;
	color: #FFFFFF;
	width: 40px;
	display: flex;
	justify-content: center;
	transition: color 0.3s ease;
}

.fm-audio-player .track-item .track-info {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	padding-left: 15px;
}

.fm-audio-player .track-item .track-info .track-title {
	font-family: "Base Neue", sans-serif;
	font-size: 24px;
	text-transform: uppercase;
	color: #FFFFFF;
	line-height: 1.1;
	transition: color 0.3s ease;
}

.fm-audio-player .track-item .track-info .track-tags {
	font-family: 'Montserrat', sans-serif;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.4);
	text-transform: uppercase;
	letter-spacing: 1px;
	margin-top: 4px;
}

.fm-audio-player .track-item .track-progress {
	position: absolute;
	bottom: 0;
	left: 0;
	height: 3px;
	width: 100%;
	background: transparent;
}

.fm-audio-player .track-item .track-progress .progress-bar {
	height: 100%;
	width: 0%;
	background: #E8A7FF;
	transition: width 0.1s linear;
}

@media (max-width: 767.98px) {
	.fm-audio-player .track-item {
		padding: 15px;
	}
	.fm-audio-player .track-item .track-info .track-title {
		font-size: 20px;
	}
}

.fm-video-showcase {
	max-width: 1200px;
	margin: 0 auto 100px;
	padding: 0 var(--spacebody-lg);
}

.fm-video-showcase .video-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

.fm-video-showcase .video-item {
	position: relative;
	border-radius: 16px;
	overflow: hidden;
	aspect-ratio: 9 / 16;
	background-color: #111;
	border: 1px solid rgba(255, 255, 255, 0.1);
	cursor: pointer;
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease, border-color 0.4s ease;
}

.fm-video-showcase .video-item video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	opacity: 0.8;
	transition: opacity 0.3s ease;
}

.fm-video-showcase .video-item .play-overlay {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: rgba(32, 32, 32, 0.5);
	backdrop-filter: blur(5px);
	border-radius: 50%;
	width: 70px;
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 1;
	transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
	pointer-events: none;
}

.fm-video-showcase .video-item:hover {
	transform: translateY(-10px);
	box-shadow: 0 30px 50px rgba(0, 0, 0, 0.8);
	border-color: rgba(232, 167, 255, 0.5);
}

.fm-video-showcase .video-item:hover video {
	opacity: 1;
}

.fm-video-showcase .video-item:hover .play-overlay {
	opacity: 0;
	transform: translate(-50%, -50%) scale(1.2);
}

@media (max-width: 991.98px) {
	.fm-video-showcase .video-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 575.98px) {
	.fm-video-showcase {
		margin-bottom: 60px;
	}
	.fm-video-showcase .video-grid {
		grid-template-columns: 1fr;
		gap: 20px;
		max-width: 400px;
		margin: 0 auto;
	}
	.fm-video-showcase .video-item.is-playing .play-overlay {
		opacity: 0;
		transform: translate(-50%, -50%) scale(1.2);
	}
}

/*--------------------------------------------------------------
>>> Cursiv Contact (Redesigned & Animated)
--------------------------------------------------------------*/
@keyframes contactFadeUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.page-id-12 h1 {
	margin-top: 120px;
	margin-bottom: 40px;
	opacity: 0;
	animation: contactFadeUp 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
}

.wpcf7 {
	margin-top: 40px;
	z-index: 998;
	position: relative;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	padding: 0 var(--spacebody-lg);
}

.wpcf7 .wpcf7-response-output, .wpcf7 .wpcf7-not-valid-tip {
	border: none !important;
	font-family: "Base Neue", sans-serif;
	font-size: 13px;
	line-height: 1.1;
	color: #E8A7FF !important;
	padding: 0 !important;
	z-index: 9;
	text-transform: uppercase;
}

.wpcf7 .wpcf7-not-valid-tip {
	margin-top: 8px;
	position: absolute;
	bottom: -22px;
	left: 15px;
}

.wpcf7 .wpcf7-response-output {
	margin-top: 30px !important;
	text-align: center;
}

.wpcf7 .contact-form {
	display: flex;
	flex-direction: column;
	gap: 25px;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap {
	width: 100%;
	position: relative;
	opacity: 0;
	animation: contactFadeUp 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap:nth-child(1) {
	animation-delay: 0.2s;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap:nth-child(2) {
	animation-delay: 0.3s;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap:nth-child(3) {
	animation-delay: 0.4s;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap:nth-child(4) {
	animation-delay: 0.5s;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap:nth-child(5) {
	animation-delay: 0.6s;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input {
	font-family: "Base Neue", sans-serif;
	font-size: clamp(20px, 3vw, 28px);
	text-transform: uppercase;
	color: #FFFFFF;
	width: 100%;
	padding: 22px 30px;
	background: rgba(232, 167, 255, 0.04);
	border: 1px solid rgba(232, 167, 255, 0.15);
	border-radius: 12px;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	outline: none !important;
	box-shadow: inset 0 0 0 transparent;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input::placeholder {
	color: rgba(255, 255, 255, 0.4);
	transition: color 0.3s ease;
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input:hover {
	background: rgba(232, 167, 255, 0.08);
	border-color: rgba(232, 167, 255, 0.4);
	transform: translateY(-2px);
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input:focus, .wpcf7 .contact-form .wpcf7-form-control-wrap input:active {
	background: rgba(232, 167, 255, 0.15);
	border-color: #E8A7FF;
	color: #E8A7FF;
	box-shadow: 0 15px 30px rgba(0, 0, 0, 0.3), 0 0 20px rgba(232, 167, 255, 0.2);
	transform: translateY(-5px);
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input:focus::placeholder, .wpcf7 .contact-form .wpcf7-form-control-wrap input:active::placeholder {
	color: rgba(255, 255, 255, 0.5);
}

.wpcf7 .contact-form .wpcf7-form-control-wrap input:not(:placeholder-shown) {
	color: #E8A7FF;
	border-color: rgba(232, 167, 255, 0.4);
}

.wpcf7 .contact-form .wpcf7-submit {
	opacity: 0;
	animation: contactFadeUp 0.8s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
	animation-delay: 0.6s;
	border: 2px solid rgba(255, 255, 255, 0.15);
	background-color: #272727;
	color: #FFFFFF;
	font-family: "Base Neue", sans-serif;
	font-size: clamp(24px, 4vw, 40px);
	letter-spacing: 2px;
	border-radius: 12px;
	text-transform: uppercase;
	padding: 30px 60px 25px;
	margin-top: 20px;
	width: 100%;
	cursor: pointer;
	position: relative;
	transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.wpcf7 .contact-form .wpcf7-submit:hover {
	background-color: #FFFFFF;
	color: #202020;
	border-color: #FFFFFF;
	transform: translateY(-5px) scale(1.02);
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4), 0 0 30px rgba(255, 255, 255, 0.15);
	letter-spacing: 6px;
}

.wpcf7 .contact-form .wpcf7-submit:active {
	transform: translateY(0) scale(0.98);
	box-shadow: none;
	letter-spacing: 2px;
}

@media (max-width: 767.98px) {
	.wpcf7 {
		padding: 0 20px;
	}
	.wpcf7 .contact-form {
		gap: 15px;
	}
	.wpcf7 .contact-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip {
		font-size: 11px;
		bottom: -18px;
	}
	.wpcf7 .contact-form .wpcf7-form-control-wrap input {
		padding: 18px 20px;
		border-radius: 8px;
	}
	.wpcf7 .contact-form .wpcf7-submit {
		padding: 22px 40px 18px;
		margin-top: 15px;
		border-radius: 8px;
	}
	.wpcf7 .contact-form .wpcf7-submit:hover {
		letter-spacing: 4px;
	}
}

@media (max-width: 575.98px) {
	.page-id-12 h1 {
		margin-top: 80px;
		margin-bottom: 30px;
	}
}

.partnerslider {
	padding: 30px;
}

.partnerslider .slick-track {
	display: flex;
	align-items: center;
}

.partnerslider {
	padding: 0;
}

.partnerslider .slick-prev.slick-arrow::before, .partnerslider .slick-next.slick-arrow::before {
	content: none;
}

.partnerslider .slick-dots {
	position: relative;
}

.partnerslider .slick-dots li button::before {
	color: #E8A7FF;
	opacity: .55;
	font-size: 13px;
}

.partnerslider .slick-dots li.slick-active button::before {
	color: #E8A7FF;
	opacity: 1;
}

/* Startseite: Slider mittig im Viewport */
.home .studio-swiper {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-left: 70px;
	padding-right: 70px;
	overflow: hidden;
	padding-top: 30px;
}

/* Swiper Container */
.studio-swiper .swiper {
	width: 100%;
	/* (B) INNER VISIBLE: erlaubt, dass Center über Nachbarn “drüber” wächst */
	overflow: visible;
}

/* Wrapper: vertikal zentrieren + genug Höhe für scale(1.1) */
.studio-swiper .swiper-wrapper {
	align-items: center;
	padding: 0 0 70px;
	/* mehr Platz nach unten wie im Referenzbild */
}

/* (1) WICHTIG: Erzwingt EXAKT 3 volle Slides (kein Raum für 4.) */
.studio-swiper .swiper-slide {
	width: calc(100% / 3) !important;
	/* killt Peek zuverlässig */
	position: relative;
	z-index: 1;
}

/* Kartenstil */
.studio-swiper .swiper-slide a {
	display: block;
	width: 100%;
	border-radius: 10px;
	overflow: hidden;
	box-shadow: 0 18px 25px rgba(0, 0, 0, 0.6);
	transform: translateZ(0);
	transition: transform .35s ease, box-shadow .35s ease;
}

.studio-swiper .swiper-slide img {
	width: 100%;
	height: auto;
	display: block;
}

/* (2) Center größer + vordergrund + überlappt Nachbarn */
.studio-swiper .swiper-slide-active {
	z-index: 5;
}

/* hier dein gewünschtes ~1.1 */
.studio-swiper .swiper-slide-active a {
	transform: scale(1.1) translateY(0);
}

.studio-swiper .swiper-slide-active {
	margin-left: 0;
	margin-right: 0;
}

/* Swiper Container */
.studio-swiper .swiper {
	width: 100%;
}

/*--------------------------------------------------------------
>>> Extras:
--------------------------------------------------------------*/
.pf-item,
.pf-item-description-content,
tr,
h3 {
	opacity: 0;
	filter: alpha(opacity=0);
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
	-webkit-transform: translateY(80px);
	-moz-transform: translateY(80px);
	-ms-transform: translateY(80px);
	-o-transform: translateY(80px);
	transform: translateY(80px);
	transition: all 1.0s ease;
}

.ani-appear, .page-id-171 h2 {
	-webkit-transform: translate(0);
	-moz-transform: translate(0);
	-ms-transform: translate(0);
	-o-transform: translate(0);
	transform: translate(0);
	opacity: 1;
	filter: alpha(opacity=100);
	-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
}

.le_portfolio-template-default h2 {
	-webkit-transform: skewY(0) scaleY(1) translateY(0) translateZ(0);
	transform: skewY(0) scaleY(1) translateY(0) translateZ(0);
	opacity: 1;
}

/* 1) Grundsätzlich: volle Höhe */
/*--------------------------------------------------------------
>>> Colors & Global Elements:
--------------------------------------------------------------*/
::selection {
	background-color: #E8A7FF;
	color: #FFFFFF;
}

html {
	background-color: #0f0f0f;
}

body {
	background-color: #0f0f0f;
	color: #FFFFFF;
	font-family: 'Montserrat', sans-serif;
	font-size: var(--body-text);
	line-height: var(--body-text-line-height);
	overscroll-behavior-y: none;
}

main {
	background-color: #202020;
}

.noise-overlay {
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 9999;
	pointer-events: none;
	background-image: url("./img/overlay-body.gif");
	background-position: 0 0;
	background-size: 480px;
	background-attachment: fixed;
	opacity: .05;
}

h1, h2, h3, h4, h5, h6 {
	font-weight: 900;
	text-transform: uppercase;
	line-height: 1.5;
}

h1 {
	font-family: "Base Neue", sans-serif;
	font-size: var(--h1-title);
	width: 100%;
	line-height: 0.82;
	white-space: nowrap;
	display: inline-block;
}

h2 {
	font-family: "Base Neue", sans-serif;
	font-size: var(--h2-title);
	line-height: 0.83;
}

h3 {
	font-family: "Base Neue", sans-serif;
	font-size: var(--h3-title);
	line-height: 1;
}

h4 {
	font-family: "dharma-gothic-c", sans-serif;
	font-style: italic;
	font-size: var(--table-text);
	font-weight: 300;
}

h5 {
	font-family: "Base Neue", sans-serif;
	font-size: var(--h5-title);
	line-height: 0.83;
}

a {
	color: #FFFFFF;
	text-decoration: none;
}

a:hover {
	text-decoration: none;
	color: #FFFFFF;
}

h1 .br-desktop, h2 .br-desktop, h3 .br-desktop {
	display: block;
}

h1 .br-mobile, h2 .br-mobile, h3 .br-mobile {
	display: none;
}

h1 .br-mobile-line, h2 .br-mobile-line, h3 .br-mobile-line {
	display: none;
}

.container {
	max-width: 1400px;
}

.container-small {
	max-width: 1200px;
}

@media (max-width: 1299.98px) {
	h1, h2, h3 {
		top: -33px;
		line-height: 0.85;
	}
	h1 .br-desktop, h2 .br-desktop, h3 .br-desktop {
		display: none;
	}
	h1 .br-mobile, h2 .br-mobile, h3 .br-mobile {
		display: block;
	}
	h1 .br-mobile-line, h2 .br-mobile-line, h3 .br-mobile-line {
		display: inline-block;
	}
}

@media (max-width: 575.98px) {
	h2 {
		margin-bottom: 30px;
	}
}

/*# sourceMappingURL=style.css.map */