/*!
Theme Name: Creatives Theme (Kadence Child)
Theme URI: https://www.kadencewp.com/kadence-theme/
Template: kadence
Author: Kadence WP
Author URI: https://www.kadencewp.com/
Description: A child theme for the Kadence Theme.
Version: 1.0.0
License: GNU General Public License v3.0 (or later)
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Text Domain: kadence-child
*/

/* Theme customization starts here

-------------------------------------------------------------- */


/* Root Variables
-------------------------------------------------------------- */

:root {
	--crea-white: #fdffef;
	--crea-black: #000000;
  	--crea-purple: #c792ff;
  	--crea-yellow: #edff5f;
  	--crea-turquoise: #00e9bd;
  	--crea-orange: #fc4607;
	/* --global-heading-font-family: "Cera PRO", serif !important; */
	/* --global-body-font-family: "Cera PRO", serif !important; */
	--border-radius: 25px 25px 0px 25px;
}


/* Global Settings
-------------------------------------------------------------- */

li[class*="wp-block"][class]:hover img {
  filter: none;
}
[class*="kb-query-block-post"][class] img {
  filter: grayscale(1);
}
[class*="kb-query-block-post"][class]:hover img {
  filter: none;
}
mark.kt-highlight {
	hyphens: auto;
}
.screen-reader-text {
	color: var(--crea-white);
}
@media (max-width: 767px) {
	h1.crea-sayno > mark:first-child {
		line-height: 8rem !important;
	}
}
#kt-scroll-up {
	z-index: 50 !important;
}
#widget-drawer {
	z-index: 100 !important;
}

/* Portfolio Grid Settings
-------------------------------------------------------------- */
.post-link-container {
    display: flex; /* Für horizontale Anordnung von Bild und Titel */
    align-items: center; /* Vertikale Zentrierung */
    border: 0px solid #ccc;
    padding: 10px;
    margin-bottom: 10px;
}

.post-link-container a,
.post-link-container a:hover {
	color: var(--crea-black);
	text-align: center;
	text-decoration: none;
}

.post-link-image {
	position: relative;
	margin-bottom: 10px;
	border-radius: 50px 50px 0px 50px;
}

.post-link-image:hover .post-link-button {
	display: flex;
}
.post-link-image:hover::before,
.post-link-image:hover::after {
	background-color: inherit;
	mix-blend-mode: inherit;
}

.post-link-image img {
	/*width: 100%;
    max-width: 600px;
    height: auto;*/
	border-radius: 50px 50px 0px 50px;
}

.post-link-image::before {
	background-color: #000000;
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	mix-blend-mode: saturation;
	position: absolute;
	top: 0;
	left: 0;
	border-radius: 50px 50px 0px 50px;
}
.post-link-image::after {
	background-color: var(--crea-purple);
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	mix-blend-mode: multiply;
	position: absolute;
	top: 0;
	left: 0;
	border-radius: 50px 50px 0px 50px;
}

.post-link-button {
	/*position: absolute;
    top: 0;
    left: 0;*/
    display: none;
    justify-content: center;
    align-items: center;
	z-index: 1;
    width: 100%;
	height: 100%;
    color: white;
    font-size: 40px;
    font-weight: 700;
}

.post-link-button img {
	position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
	width: auto;
    max-width: 200px;
    height: auto;
    border-radius: inherit;
}

.post-link-categories {
	position: absolute;
	z-index: 1;
    bottom: 6px;
    right: 6px;
    max-width: 80%;
    display: flex;
    flex-direction: row;
	justify-content: end;
    flex-wrap: wrap;
}

.post-link-categories span {
	background: var(--crea-white);
	color: var(--crea-black);
	font-size: var(--wp--preset--font-size--small);
    margin: 2px 3px;
    padding: 0px 8px;
    border-radius: 10px 10px 0px 10px;
}

.post-link-title {
    font-weight: normal;
}
.post-link-title:focus {
	color: var(--crea-black) !important;
}

.post-link-customer {
	font-weight: bold;
}

figure.wp-block-video {
	margin: 0;
}



/* Portfolio Grid Modal Overlay Settings
-------------------------------------------------------------- */

.kt-image-overlay-message {
	/*pointer-events: none !important;*/
}

.modal {
    display: none; /* Anfangs ausgeblendet */
    position: fixed;
    z-index: 101;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(253,255,239,0.8);
}

.modal-content {
	position: relative;
	margin: 20px auto;
	padding: 0px;
	border: 0px solid var(--crea-purple);
	width: calc(100% - 140px);
	max-width: 1920px;
	height: calc(100% - 40px);
	max-height: 100vh;
	overflow-y: auto;
}
@media only screen and (max-width: 600px) and (orientation: portrait) {
    .modal-content {
		margin: 0px auto;
		width: 100%;
		height: 100%;
	}
}

#modal-content-inner {
	background-color: var(--crea-black);
}

.close-modal {
	position: fixed;
    margin-left: auto;
	right: 3px;
    top: 12px;
	z-index: 102;
	display: flex;
	flex-direction: column;
    align-items: center;
    justify-content: center;
	width: 60px;
    height: 60px;
    color: var(--crea-black);
    cursor: pointer;
}
body.slug-fun-mode .close-modal {
	cursor: none;
}
.close-modal > span:first-child {
	font-size: 58px;
    font-weight: 300;
	line-height: .7;
}
.close-modal > span:last-child {
	font-size: 12px;
    font-weight: 300;
}
@media only screen and (max-width: 600px) and (orientation: portrait) {
    .close-modal {
		color: var(--crea-yellow);
	}
}


/* Portfolio Template CSS
-------------------------------------------------------------- */

.p-container {
    display: flex;
}

.p-info {
  	flex: 2 1 auto;
    display: flex;
  	flex-basis: 66.66%; 
    flex-direction: column;
    align-self: stretch;
    justify-content: space-between;
    padding-top: 5rem;
}
.p-info .p-text {
    padding: 3rem 5rem;
}
.p-info h1 {
    font-size: 3rem;
    color: var(--crea-purple);
    font-weight: bold;
    margin-top: 4rem;
}
.p-info .p-content {
    margin-top: 5rem;
    font-size: 2rem;
}
.p-info .p-content-tags {
    display: flex;
    flex-direction: row;
    gap: .5rem;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
    font-size: 1.5rem;
}
.p-info .p-content-tags :first-child {
    margin-bottom: 0;
}
.p-info .p-content-tags :last-child {
    margin-top: 0;
}
.p-info .p-btn {
    background-color: var(--crea-white);
    color: var(--crea-black);
    padding: 10px 20px;
    margin-top: 3rem;
    border-radius: var(--border-radius);
    font-size: 2rem;
    font-weight: bold;
}

.p-posts,
.p-posts-mobile {
    display: flex;
    flex-direction: row;
    justify-content: center;
    gap: 50px;
    background-color: var(--crea-purple);
    padding: 3rem;
}
.p-posts-mobile {
	display: none;
}
.p-posts a,
.p-posts-mobile a{
    display: flex;
    gap: 20px;
    align-items: center;
    text-decoration: none;
}
.p-posts a span,
.p-posts-mobile a span {
    color: var(--crea-black);
}
.p-posts a.load-previous-post span,
.p-posts-mobile a.load-previous-post span,
.p-posts a.load-previous-post-single span,
.p-posts-mobile a.load-previous-post-single span {
    text-align: right;
}
.p-posts img {
    max-width: 80px;
}
.p-posts img.p-previous {
    transform: rotate(180deg);
    max-width: 80px;
}

.p-video {
  	flex: 1 1 auto;
    display: flex;
  	flex-basis: 33.33%; 
	align-items: start;
    aspect-ratio: 9/16;
	position: relative;
	width: 100%;
	max-width: 100%;
}
.p-video video {
	width: 100%;
    min-width: 500px;
}
.p-video.video-mobile {
	display: none;
}
.p-video.video-mobile video {
	width: 100%;
	min-width: inherit;
}
a.p-link-overview {
	display: flex;
    flex-direction: row;
    align-items: center;
    gap: 15px;
    font-size: 2rem;
	padding: 3rem 5rem;
}
a.p-link-overview img {
	max-width: 50px;
	height: auto;
}
.p-video .p-play,
.p-video .p-pause {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 50px;
    height: auto;
    margin: 15px;
	display: none;
}

@media only screen and (max-device-width: 1024px) {
	.p-container {
        flex-wrap: wrap;
    }
    .p-info .p-text {
		padding: .6rem 1rem;
	}
	.p-info h1 {
    	font-size: 2rem;
	}
	.p-info .p-content-tags {
        flex-direction: column;
		flex-wrap: wrap;
		font-size: 1rem;
		gap: 0px;
	}
	.p-info .p-btn {
		font-size: 1rem;
	}
	.p-info .p-content {
		margin-top: 2rem;
	}
	.p-posts {
		display: none;
	}
	.p-posts a {
		flex-wrap: wrap;
		justify-content: center;
	}
	.p-posts a.load-previous-post {
		flex-direction: column-reverse;
    	align-items: flex-end;
	}
	.p-posts a.load-next-post {
		flex-direction: column;
    	align-items: flex-start;
	}
	.p-posts-mobile {
		display: flex;
		width: 100%;
		padding: 2rem;
	}
	.p-posts-mobile a {
		flex-direction: column-reverse;
	}
	.p-posts-mobile a.load-next-post {
		flex-direction: column;
	}
	.p-posts-mobile a span {
		text-align: center !important;
	}
	.p-posts-mobile img {
		max-width: 50px;
	}
	.p-posts-mobile img.p-previous {
		transform: rotate(180deg);
		max-width: 50px;
	}
	.p-video {
		max-width: 100%;
		flex-basis: 100%;
	}
	.p-video video {
		width: 100%;
		min-width: inherit;
	}
	.p-video.video-mobile {
		display: flex;
	}
}


.kb-splide .splide__arrow {
    font-size: 1rem !important;
    background: var(--crea-white) !important;
    border-radius: 100px !important;
    border: 2px solid var(--crea-purple) !important;
    height: 4em !important;
    width: 4em !important;
    opacity: 1 !important;
    color: var(--crea-black) !important;
	top: 45% !important;
}
.kb-splide .splide__arrow--next {
	right: -1rem !important;
}
.kb-splide .splide__arrow--prev {
    left: -1rem !important;
}



/* Portfolio Filter Settings
-------------------------------------------------------------- */

.kb-post-filter-container {
	margin-bottom: 40px !important;
}
.kb-filter-item {
	line-height: 1 !important;
	margin: 0 !important;
	position: relative !important;
}
.kb-filter-item::before {
	content: attr(data-text);
	font-weight: 700;
	visibility: hidden;
    position: absolute;
	white-space: nowrap;
}
.kb-filter-item::after {
  	content: attr(data-text);
  	font-weight: 700;
  	visibility: hidden;
  	display: block;
  	height: 0;
  	overflow: hidden;
}
.kb-filter-item:hover {
	font-weight: 700 !important;
}
.kb-filter-item.is-active {
	font-weight: bold !important;
	color: var(--crea-black) !important;
}
.kb-filter-separator {
	display: flex;
    align-self: center;
    color: var(--crea-purple);
	font-size: .55rem;
    margin-top: 0rem;
    padding: 0px 10px;
}



/* Navigation Settings
-------------------------------------------------------------- */

.drawer-toggle {
	border-radius: 20px 0px 20px 20px;
}
input.search-field {
	border-radius: 20px 0px 20px 20px !important;
}
.site-header-item {
	align-items: baseline !important;
}
.kb-nav-link-content {
	width: auto !important;
    padding: 25px 0px 10px 0px !important;
    border-bottom: 4px solid var(--crea-black);
}
.kb-nav-link-content:hover {
	border-bottom: 4px solid var(--crea-yellow);
}
.kb-nav-link-content_dot {
	display: flex;
	align-self: center;
	font-size: 3rem;
    color: var(--crea-yellow);
    padding: 15px 10px 5px 10px;
	line-height: .4;
}
li > div.kb-link-wrap {
	margin-bottom: 20px;
}
.kb-nav-link-content.active {
	color: var(--crea-yellow) !important;
	border-bottom: 4px solid var(--crea-yellow);
}
.drawer-inner .drawer-logo {
	padding: 39px 30px 5px 30px;
	margin: 0 auto;
	max-width: var(--global-content-width);
}
.drawer-header {
	max-width: var(--global-content-width);
}
@media (max-width: 1024px) {
    .drawer-inner .drawer-logo {
		padding: 0px 0px 10px 0px;
	}
}




/* Mobile Navigation Settings
-------------------------------------------------------------- */




/* Portfolio Settings
-------------------------------------------------------------- */

/*
.kt-image-overlay-wrap img {
	filter: grayscale(1);
	-webkit-transition: all 2s;
    transition: all 2s;
}
.kt-image-overlay-wrap:hover img {
	filter: grayscale(0);
}
a.kt-imageoverlay-link {
	background: rgba(199, 146, 255, .8) !important;
	mix-blend-mode: multiply;
    -webkit-transition: background 2s;
    transition: all 2s;
}
a.kt-imageoverlay-link:hover {
	background: rgba(199, 146, 255, .0) !important;
	mix-blend-mode: normal;
}
.kt-image-overlay-inner h5 {
	background-image: url('https://creatives.duwfamily.de/wp-content/uploads/2024/11/btn_projekt.svg');
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
}
*/

/* Category filter */

button[aria-pressed="true"] {
    font-weight: bolder;
}

.btn-inner-wrap::before {
	content:' ';
}
.btn-inner-wrap:not(:last-child):after {
	content: url('data:image/svg+xml, %3Csvg height="100" width="100" xmlns="http://www.w3.org/2000/svg"%3E%3Ccircle r="6" cx="16" cy="16" fill="%23c792ff" /%3E%3C/svg%3E');
	width: 20px;
	height: 20px;
}

/* Category block button */
.is-style-category {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: end;
}
.is-style-category a {
    display: inline-block;
    background: var(--crea-white);
    color: var(--crea-black);
	pointer-events: none;
    text-decoration: none!important;
    border-radius: 10px 10px 0px 10px;
    padding: 0px 8px 0px 8px;
	margin: 4px 0px;
}
.customers-link > a {
	text-decoration: none !important;
}


/* Formular Settings
-------------------------------------------------------------- */

.wp-block-kadence-advanced-form .kb-adv-form-required {
    margin-left: 5px !important;
    color: var(--crea-orange) !important;
}

.kb-field.kb-text-field,
.kb-field.kb-email-field,
.kb-field.kb-textarea-field {
	padding: 12px 12px 12px 18px !important;
}
.kb-adv-form-field input,
.kb-adv-form-field textarea {
	outline: 2px solid var(--crea-black);
	outline-offset: 2px;
}
.kb-adv-form-field input:focus,
.kb-adv-form-field textarea:focus {
	outline: 2px solid var(--crea-turquoise) !important;
	outline-offset: 2px;
}
.kb-adv-form-warning {
	margin-top: 5px !important;
}
.kb-adv-form-warning.valid {
	color: var(--crea-turquoise) !important;
}
.kb-radio-check-item {
	align-items: center !important;
}
.kb-radio-check-item > input {
	border-color: var(--crea-orange) !important;
    border-radius: 7px 7px 0px 8px !important;
	accent-color: #34495e;
}
.kb-form-basic-style input[type=checkbox]:checked {
	background: var(--crea-orange) !important;
}
.kb-radio-check-item > label {
	padding-left: 10px !important;
}
.kb-radio-check-item > label a,
.kb-radio-check-item > label a:hover {
	color: var(--crea-white);
}
.kb-form-basic-style .kb-radio-check-item label {
	font-size: 0.9rem !important;
}
.crea-contact-form .wp-block-kadence-advanced-form {
	display: flex;
  	flex-direction: column;
  	justify-content: center;
}
.crea-contact-form form {
	margin-bottom: 0px !important;
  	max-width: 700px
}
.crea-contact-form .kb-adv-form-message.kb-adv-form-success {
	position: absolute;
	z-index: 1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 800px;
    width: 100%;
    min-height: 400px;
    height: auto;
    font-size: 3.4rem;
    line-height: 1.2;
    font-weight: 700;
    padding: 50px;
	background-image: url('https://creatives.duwfamily.de/wp-content/uploads/2025/02/computer.svg');
	background-repeat: no-repeat;
	background-position: calc(100% - 10px) calc(100% - 10px);
	background-size: 14rem;
}
@media only screen and (max-width: 600px) and (orientation: portrait) {
    .crea-contact-form .kb-adv-form-message.kb-adv-form-success {
		font-size: 1.8rem;
		background-size: 9rem;
	}
}
.crea-contact-form .kb-adv-form-message.kb-adv-form-success:before,
.crea-contact-form .kb-adv-form-message.kb-adv-form-success:after {
	content: '';
    position: absolute;
    top: -18px;
	bottom: auto;
    left: 0;
    width: 100%;
    height: 40px;
    background-image: url(https://creatives.duwfamily.de/wp-content/uploads/2024/11/devider2.svg);
    background-size: 40px;
    background-repeat: round;
}
.crea-contact-form .kb-adv-form-message.kb-adv-form-success:after {
	top: auto;
	bottom: -18px;
}
.wp-block-kadence-advanced-form.kb-form-has-background {
    padding: 0em !important;
}
[data-type="accept"] > div.kb-radio-check-item {
	padding-left: 20px;
}
.kb-form-basic-style input[type=checkbox] {
	min-width: 20px !important;
	min-height: 20px!important;
}



/* Footer Settings
-------------------------------------------------------------- */


/** styled modal **/
.modal-wrapper.styled {
    background-color: rgb(0, 0, 0); /* Fallback color */
    background-color: rgba(0, 0, 0, 0.6); /* Black w/ opacity */
}

.modal-wrapper.styled .wp-post-modal {
    position: relative;
	background-color: var(--crea-purple);
	margin: 10vh auto;
	padding: 10px;
	border: 0px solid var(--crea-purple);
	width: 70%;
	transition: all 2s ease;
	border-radius: 10px;
}

.modal-wrapper.styled .wp-post-modal .close-modal {
    background: transparent;
    position: absolute;
    top: -6px;
    right: 10px;
    font-size: 2.0em;
    color: #333;
    cursor: pointer;
}

.modal-wrapper.styled .wp-post-modal header.site-header,
.modal-wrapper.styled .wp-post-modal footer {
	display: none;
}

.modal-wrapper.styled .wp-post-modal #wrapper {
	border-radius: 6px;
}

.modal-wrapper.styled .wp-post-modal #modal-content {
	background: var(--crea-black);
	border-radius: 6px;
}

.modal-wrapper.styled .wp-post-modal #inner-wrap {
	padding: 2rem;
}

.modal-wrapper.styled .modal h1 {
    font-size: 36px;
    margin: 35px 0;
}

.modal-wrapper.styled .wp-post-modal .entry-content p {
    font-size: 16px;
}

.modal-wrapper.styled .wp-post-modal .loading {
    display: block;
    width: 100px;
    margin: auto;
    padding: 25vh 0;
}

.modal-wrapper.styled .wp-post-modal p {
    font-size: 16px;
    font-family: Helvetica, Arial, sans-serif;
    text-rendering: optimizeLegibility;
    color: #444;
    line-height: 1.5em;
    margin-bottom: 0.8em;
}

.modal-wrapper.styled .wp-post-modal h1, h2, h3, h4, h5, h6 {
    font-family: Helvetica, Arial, sans-serif;
}

.modal-wrapper.styled .wp-post-modal h1 {
    font-size: 2.5em;
    margin: 0.3em 0;
}

.modal-wrapper.styled .wp-post-modal h2 {
    font-size: 2.0em;
    margin: 0.3em 0;
}

.modal-wrapper.styled .wp-post-modal h3 {
    font-size: 1.75em;
    margin: 0.3em 0;
}

.modal-wrapper.styled .wp-post-modal h4 {
    font-size: 1.50em;
    margin: 0.3em 0;
}

.modal-wrapper.styled .wp-post-modal h5 {
    font-size: 1.25em;
    margin: 0.3em 0;
}

.modal-wrapper.styled .wp-post-modal h6 {
    font-size: 1.0em;
    margin: 0.3em 0;
    line-height: 1.5em;
}

.modal-wrapper.styled .wp-post-modal ul li, .modal-wrapper.styled .wp-post-modal ol li {
    line-height: 1em;
    padding-bottom: 0.5em;
    text-align: justify;
}

.modal-wrapper.styled .wp-post-modal ul li {
    list-style: disc;
    margin-left: 30px;
}

.modal-wrapper.styled .wp-post-modal ol li {
    list-style: decimal;
    margin-left: 30px;
}

.modal-wrapper.styled .wp-post-modal ol ol {
    padding: 0.6em;
}

.modal-wrapper.styled .wp-post-modal dt {
    font-weight: bold;
    text-decoration: underline;
}

.modal-wrapper.styled .wp-post-modal dd {
    margin: 0;
    padding: 0.5em 0 0.5em 0;
}

.modal-wrapper.styled .wp-post-modal hr {
    border: 0;
    height: 30px;
    border-style: solid;
    border-color: #8c8c8c;
    border-width: 1px 0 0 0;
    border-radius: 20px;
    background-color: white;
    margin: 25px;
}

.modal-wrapper.styled .wp-post-modal hr:before {
    display: block;
    content: "";
    height: 30px;
    margin-top: -31px;
    border-style: solid;
    border-color: #8c8c8c;
    border-width: 0 0 1px 0;
    border-radius: 20px;
}

.modal-wrapper.styled .wp-post-modal blockquote {
    display: block;
    background: #fff;
    padding: 15px 20px 15px 45px;
    margin: 0 0 20px;
    position: relative;

    /*Font*/
    font-family: Georgia, serif;
    font-size: 16px;
    line-height: 1.2;
    color: #666;
    text-align: justify;

    /*Borders - (Optional)*/
    border-left: 7px solid #009c7b;
    border-right: 1px solid #009c7b;

    /*Box Shadow - (Optional)*/
    -moz-box-shadow: 2px 2px 15px #ccc;
    -webkit-box-shadow: 2px 2px 15px #ccc;
    box-shadow: 2px 2px 15px #ccc;
}

.modal-wrapper.styled .modal blockquote::before {
    content: "\201C"; /*Unicode for Left Double Quote*/

    /*Font*/
    font-family: Georgia, serif;
    font-size: 60px;
    font-weight: bold;
    color: #999;

    /*Positioning*/
    position: absolute;
    left: 10px;
    top: 5px;
}

.modal-wrapper.styled .modal blockquote::after {
    /*Reset to make sure*/
    content: "";
}

.modal-wrapper.styled .modal blockquote a {
    text-decoration: none;
    background: #eee;
    cursor: pointer;
    padding: 0 3px;
    color: #c76c0c;
}

.modal-wrapper.styled .modal blockquote a:hover {
    color: #666;
}

.modal-wrapper.styled .modal blockquote em {
    font-style: italic;
}

.modal-wrapper.styled .modal blockquote cite {
    color: #999999;
    font-size: 14px;
    display: block;
    margin-top: 5px;
}

.modal-wrapper.styled .modal blockquote cite:before {
    content: "\2014 \2009";
}

.modal-wrapper.styled .modal table {

    color: #757575;
    font-size: 1em;
    line-height: 2;
    margin: 0 0 24px;
    width: 100%;
}

.modal-wrapper.styled .modal input[type=password] {
    margin: 5px 0 10px;
    width: 25%;
    padding: 7px 0 7px 4px;
    border: 1px solid #E3E3E3;
}

/* Footer Settings
-------------------------------------------------------------- */

footer .kb-svg-icon-wrap svg {
	height: auto !important;
}
footer a.social-button {
	width: 1.2em;
  	height: 1.2em;
}
footer .footer-widget-area {
	align-items: end;
}


/* FAQs
-------------------------------------------------------------- */

.wp-block-kadence-pane.kt-accordion-pane {
	display: flex;
    flex-direction: column;
}
.kt-blocks-accordion-header {
	width: 90% !important;
}
.kt-accordion-panel {
  	display: flex;
    flex-direction: row;
    align-self: end;
	width: 90%;
    margin-top: 15px;
}


/* Datenschutz/Impressum
-------------------------------------------------------------- */

.datenschutz h2,
.impressum h2{
	color: var(--crea-purple);
}
.datenschutz h2::first-letter {
	color: var(--crea-turquoise);
}

/* Animations/Lottifiles
-------------------------------------------------------------- */

.crea-augenfisch dotlottie-player {
	max-width: 300px;
}
@media (max-width: 992px) {
    .crea-augenfisch dotlottie-player {
		max-width: 200px;
	}
}
.crea-jaennifer {
	pointer-events: none;
}
.crea-jaennifer dotlottie-player {
	position: absolute;
	z-index: -1;
    top: calc(2.75*-10rem);
    right: -60%;
}
.crea-jaennifer dotlottie-player svg rect {
	fill: transparent;
}
@media (max-width: 992px) {
	.crea-jaennifer dotlottie-player {
		position: absolute;
		z-index: -1;
		top: -30em;
		right: 0;
		left: 0;
		overflow: hidden;
		width: 1000px;
	}
}

/* Fun-Mode
-------------------------------------------------------------- */

.mobile-header-button {
	padding: 0 !important;
}
.site-header-section-right {
	padding-top: 5px;
}

.crea-futureisland-wrapper {
	min-height: auto;
}
.crea-futureisland img {
	min-width: 950px;
	animation-name: futureisland;
  	animation-duration: 4s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-timing-function: ease-out;
}
.crea-retroisland img {
	min-width: 950px;
	margin-left: -40px;
}

.crea-fm-header {
	margin-top: -160px;
	margin-bottom: -60px;
	/* min-height: 700px; */
}
@media (min-width: 600px) and (max-width: 991px) {
    .crea-fm-header {
        margin-top: -80px;
    }
}
@media (min-width: 992px) {
	.crea-fm-header {
		margin-top: 0px;
	}
	.crea-futureisland-wrapper > div {
		min-height: 500px;
	}
	.crea-futureisland img {
		min-width: 520px;
	}
	.crea-retroisland img {
		min-width: 730px;
        margin-left: -70px;
	}
}

@keyframes futureisland {
  from {
    margin-top: 20px;
  }
  to {
    margin-top: 0px;
  }
}

#funmode-container {
	display: none;
    position: fixed;
	z-index: 101;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    overflow: hidden;
}

#backgroundCanvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.funmode-buttons {
	display: flex;
    flex-direction: row;
    z-index: 10;
}

.funmode-btn {
    padding: 16px 0px 18px 0px;
	margin: auto 10px;
    width: 180px;
    height: auto;
	background-color: transparent;
	background-image: url(./assets/images/btn-funmode.svg);
    background-repeat: no-repeat;
    background-position: center;
    color: black;
    cursor: pointer;
	font-family: "Pixelify Sans", serif;
	font-weight: 500;
	font-size: 2rem;
    line-height: 1.4;
	text-align: center;
}

.funmode-btn:hover {
    background-color: transparent;
	background-image: url(./assets/images/btn-funmode-hover.svg);
    background-repeat: no-repeat;
    background-position: center;
}

#funmode-text-wrapper {
	display: flex;
	height: 100%;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}

.funmode-text {
    color: white;
    background: rgba(0, 0, 0, 1);
    padding: 25px;
    border-radius: 8px;
    z-index: 5;
    display: none;
	font-family: "Pixelify Sans", serif;
	font-weight: 500;
	text-align: center;
	font-size: 2.8rem;
    line-height: 1.2;
}

.funmode-hint {
    color: white;
    background: rgba(0, 0, 0, 1);
    padding: 25px;
    border-radius: 8px;
    z-index: 5;
    text-align: center;
    width: 100%;
    max-width: 400px;
	white-space: pre-line;
	font-family: "Pixelify Sans", serif;
	font-weight: 500;
	font-size: 2.8rem;
    line-height: 1.2;
}

.site-header-section-left .header-button-inner-wrap,
.site-header-section-left .mobile-header-button-inner-wrap {
	height: 64px;
	background-image: url(./assets/images/btn-funmode-off.svg);
	background-repeat: no-repeat;
	background-position: center;
}
.site-header-section-left .header-button-inner-wrap a,
.site-header-section-left .mobile-header-button-inner-wrap a {
	border: none !important;
	color: transparent !important;
}
.site-header-section-left .header-button-inner-wrap:hover,
.site-header-section-left .mobile-header-button-inner-wrap:hover {
	background-image: url(./assets/images/btn-funmode-off-hover.svg);
}
body.slug-fun-mode .site-header-section-left .header-button-inner-wrap,
body.slug-fun-mode .site-header-section-left .mobile-header-button-inner-wrap {
	background-image: url(./assets/images/btn-funmode-on.svg);
}
body.slug-fun-mode .site-header-section-left .header-button-inner-wrap:hover,
body.slug-fun-mode .site-header-section-left .mobile-header-button-inner-wrap:hover {
	background-image: url(./assets/images/btn-funmode-on-hover.svg);
}

/* Typing Effect ALOHA */
.typing-effect {
  display: inline-block;
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
}

.typing-effect mark {
  display: inline-block;
  opacity: 0;
  transition: opacity 0s ease-out;
}

.typing-effect mark.hidden {
  opacity: 0;
}

.typing-effect mark.visible {
  opacity: 1;
}

/* Cursor */
body.slug-fun-mode,
body.slug-fun-mode a,
body.slug-fun-mode button,
body.slug-fun-mode input,
body.slug-fun-mode textarea,
body.slug-fun-mode label,
body.slug-fun-mode #newsticker-pause {
	cursor: none !important;
}
body.slug-fun-mode .cursor {
	position: absolute;
    z-index: 110;
    width: 40px;
    height: 40px;
	background-color: #00e9bd; /* Farbe des Kreises */
	border-radius: 50%; /* Macht den Kreis rund */
	border: 2px solid #00e9bd;
	pointer-events: none; /* Verhindert Interaktion mit dem Kreis */
	opacity: 0.9; /* Transparenz */
	transition: width 0.2s ease, height 0.2s ease; /* Für eine flüssige Bewegung */
}
body.slug-fun-mode #cursor.active-hover {
	width: 50px !important;
    height: 50px !important;
	border: 2px solid #fdffef !important;
}
/* body.slug-fun-mode .p-pause:hover {
	background-color: red;
} */
/* Auf Touchgeräten ausblenden */
.touch-device .cursor {
	display: none;
}
@media (hover: none) and (pointer: coarse) {
  .cursor {
    display: none;
  }
}


/* Googly Eyes */
#devider1-funmode {
	max-width: 520px;
    width: 100%;
    height: auto;
	margin-top: 12px;
}
.kb-vector-container {
	width: 100%;
}

/* Stacked Elements Block
-------------------------------------------------------------- */

.stacked-elements {
	position: relative;
	min-width: 950px;
	width: 100%; /* oder eine feste Breite */
	height: 700px; /* Anpassen je nach Bedarf */
}
@media only screen and (max-width: 600px) and (orientation: portrait) {
    .stacked-elements {
		min-width: 650px;
		height: 480px;
	}
}

.stacked-elements img {
	position: absolute;
	width: 100%; /* oder spezifische Breite */
	height: auto; /* oder spezifische Höhe */
	object-fit: cover; /* Anpassung für bessere Darstellung */
  	pointer-events: none;
	
	animation-name: futureisland;
  	animation-duration: 4s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-timing-function: ease-out;
}

.layer-1 {
	top: 0;
	left: 0;
	z-index: 1;
	opacity: 1;
}

.layer-2 {
	top: 0px; /* Beispiel-Versatz */
	left: 0px;
	z-index: 2;
	opacity: 1;
}
.layer-2 img {
	animation-name: futureisland-moon;
  	animation-duration: 6s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
	animation-timing-function: ease-in-out;
}
@keyframes futureisland-moon {
	from {
	  margin-top: 20px;
	}
	to {
	  margin-top: 0px;
	}
  }

.layer-3 {
	top: 0px; /* Beispiel-Versatz */
	left: 0px;
	z-index: 3;
	opacity: 1;
}

.layer-3 img {
	animation-name: futureisland-dome;
  	animation-duration: 8s;
	animation-iteration-count: infinite;
	animation-direction: reverse;
	animation-timing-function: ease-in-out;
}
@keyframes futureisland-dome {
	0% {
	  	margin-top: 0px;
	  	margin-left: 5px;
	}
	25% {
		margin-top: 0px;
		margin-left: 0px;
	}
	50% {
		margin-top: 10px;
		margin-left: 0px;
	}
	75% {
	  	margin-top: 10px;
	  	margin-left: 5px;
	}
	100% {
		margin-top: 0px;
		margin-left: 5px;
  	}
}

.stacked-elements-2 {
	position: relative;
	max-width: 950px;
	width: 100%;
	aspect-ratio: 1920 / 1101;
}
@media (max-width: 600px) and (orientation: portrait) {
    .stacked-elements-2 {
		min-width: 650px;
		height: 540px;
	}
}
@media (min-width: 600px) and (max-width: 991px) {
    .stacked-elements-2 {
		min-width: 650px;
		max-width: 950px;
		height: 545px;
	}
}
.stacked-elements-2 img {
	position: absolute;
	top: 50%;
    left: 50%;
    right: 0;
    bottom: 0;
	width: 100%; /* oder spezifische Breite */
	height: auto; /* oder spezifische Höhe */
	object-fit: cover; /* Anpassung für bessere Darstellung */
  	pointer-events: none;
	transform: translate(-50%, -50%);
}