/*
Theme Name: SKP Agentur & Studio
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: Erstellt durch Schlitzer, Koch & Partner Werbeagentur GmbH
*/

:root {

  /* =========================
     Farbschema – Light Theme
     ========================= */
  --color-bg: #ffffff;
  --color-bg-muted: #f3f2ef;

  --color-text: #4b5055;
  --color-text-muted: #989898;
  --color-border: #cacaca;

  --color-coral: #E63913;
  --color-coral-hover: #E63913;
  --color-coral-soft: #eec7be;

  --color-ice: #B2CDE6;
  --color-ice-hover: #9fcaf2;
  --color-ice-soft: #cde2f5;

  --color-accent: #ec4899;
  --color-danger: #dc2626;
  --color-success: #16a34a;
  --color-warning: #f59e0b;

  /* =========================
     Typografie
     ========================= */
  /* Basis-Fonts */

  --font-body: 'Lexend', sans-serif;

  /* Grundgrößen (rem basiert = responsive) Scale Tokens  */
  
  --font-size-xs: 1rem;
  --font-size-sm: 1.2rem;
  --font-size-base: 1rem;
  --font-size-regular: 1.5rem;
  --font-size-lg: 2rem;
  --font-size-xl: 4.125rem;
  --font-size-2xl: 6.25rem;
  --font-size-3xl: 8.875rem;
  --font-size-main-nav: 1.5rem;

  /* Spacings */
  --spacing-1: 1.5rem;

  /* Semantische Variablen / Role Tokens  */

  --font-size-body: var(--font-size-regular);
  --font-size-h1: var(--font-size-3xl);
  --font-size-h2: var(--font-size-2xl);
  --font-size-h3: var(--font-size-xl);
  --font-size-h4: var(--font-size-lg);

  /* Zeilenhöhe */
  --line-height-tight: 1.1;
  --line-height-snug: 1.2;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.7;

  /* Font-Weight */
  --font-weight-light: 300;
  --font-weight-semibold: 600;
  --font-weight-bold-extra-bold: 800;
}

/*
@media (prefers-color-scheme: dark) {
  :root {
    --color-bg: #020617;
    --color-bg-muted: #111827;
    --color-surface: #020617;

    --color-text: #e5e7eb;
    --color-text-muted: #9ca3af;
    --color-border: #1f2937;

    --color-primary-soft: rgba(37, 99, 235, 0.18);
  }
}
  */


/* Global */

body {
  transition: all 0.3s ease-out;
  font-family: var(--font-body);
}

body.dialog-prevent-scroll #content, body.dialog-prevent-scroll header, body.dialog-prevent-scroll footer {
  filter: blur(10px);
}

.entry-title {
  display: none;
}

.rounded {
  border-radius:35px;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.hide {
  display: none;
}

.no-margin, .no-margin p, .no-margin h1, .no-margin h2 {
  margin: 0 !important;
}

.auto-width {
  width: auto;
  flex-shrink: 0 !important;
}

/* Videooverlay */

.video-overlay .elementor-widget-image {
  opacity: 1;
  transition: all 0.3s ease-out;
}

.video-overlay:hover .elementor-widget-image {
  opacity: 0;
}

.video-overlay {
  border-radius: 35px;
  transition: all 0.3s ease-out;
}

.video-overlay:hover {
  border-radius: 15px;
}




/* Counter */
.skp-counter .elementor-counter {
  flex-direction: row-reverse;
}

.skp-counter .elementor-counter-number-prefix, .skp-counter .elementor-counter-number-suffix {
  display: none;
}

.skp-counter .elementor-counter-number-wrapper {
  display: inline-block;
  margin-right: 20px;
  text-align: left;
  width: auto;
  flex: 0;
}

.skp-counter .elementor-counter-title {
  justify-content: flex-start;
  font-size: var(--font-body);
  font-weight: var(--font-weight-light);
}
/*
.widget-image-caption {
  position: absolute;
  bottom: 4%;
  right: 4%;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-light);
  font-style: inherit;
  color: #FFF;
  padding: 4px 20px;
  border-radius: 20px;
  background: rgba(0, 0, 0, 0.3);
}
  */

.caption-duesseldorf:after {
  content:'Standort Düsseldorf';
  position: absolute;
  bottom: 40px;
  right: 30px;
  background: var(--color-coral);
  color: #FFF;
  padding: 10px 20px;
  border-radius: 50px;
  z-index: 2;
}

.caption-hagen:after {
  content:'Standort Hagen';
  position: absolute;
  bottom: 40px;
  right: 30px;
  background: var(--color-coral);
  color: #FFF;
  padding: 10px 20px;
  border-radius: 50px;
  z-index: 2;
}

/* Typography */

html {
  font-size: 16px;
  /* Basis für rem */
}

body {
  margin: 0;
  padding: 0;
  font-family: var(--font-body);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-light);
  line-height: var(--line-height-normal);
  color: var(--color-text);
  background-color: var(--color-bg);
}

/* Headings */

.elementor-heading-title {
  line-height: var(--line-height-snug);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  color: var(--color-text);
  font-weight: var(--font-weight-semibold);
  line-height: var(--line-height-normal);
  font-family: var(--font-body);
}

h1.hero-hl {
  font-size: var(--font-size-3xl);
}

h1 {
  font-size: var(--font-size-xl);
}

h2 {
  font-size: var(--font-size-xl);
}

h3 {
  font-size: var(--font-size-lg);
}

h4 {
  font-size: var(--font-size-regular);
}

.h3 h1, .h3 h2  {
  font-size: var(--font-size-lg);
}

.h4 h1, .h4 h2, .h4 h3  {
  font-size: var(--font-size-regular);
}

.formal h2 {
  font-size: var(--font-size-lg);
}

.formal h3, .formal h4 {
  font-size: var(--font-size-regular);
}

p {
  margin-top: 0;
  margin-bottom: var(--spacing-1);
}

strong {
  font-weight: var(--font-weight-semibold);
}

/* Muted Text */
.text-muted {
  color: var(--color-text-muted);
}

/* Links */
a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-primary-hover);
  text-decoration: underline;
}

/* Buttons */

/* Button Weiss */

.btn-wht a, .btn-wht a:focus, .btn-wht a:visited {
    background: #FFF;
    padding: 20px 30px 25px 30px;
    color: var(--color-coral);
    text-decoration: none;
    border-radius: 50px;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    transition: all 0.3s ease-out;
}

.btn-wht a:hover {
    border-radius: 15px;
    transform: scale(1.05);
    color: var(--color-coral);
}

/* Button Coral */

.btn-coral a, .btn-coral a:focus, .btn-coral a:visited {
    background: var(--color-coral);
    padding: 20px 30px 25px 30px;
    color: #FFF;
    text-decoration: none;
    border-radius: 50px;
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    transition: all 0.3s ease-out;
}

.btn-coral a:hover {
    background: var(--color-ice);
    border-radius: 15px;
    transform: scale(1.05);
}

/* Intro Animation */
/* Body sperren während Intro */
body.intro-active {
  overflow: hidden;
}

/* Vollbild-Overlay */
#intro-overlay {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999999999999999;
  background: var(--color-bg-muted) !important;
  opacity: 1;
  transition: opacity 0.8s ease;
}

/* Ausblenden-Animation */
#intro-overlay.intro-overlay--hide {
  filter: blur(20px);
  opacity: 0;
  pointer-events: none;
}

/* Überspringen-Button, falls du einen möchtest */
.intro-skip-btn {
  position: absolute;
  bottom: 40px;
  right: 40px;
  z-index: 10000;
}

/* Ende Intro Animation */



/* Header */

.header-logo-ice {
    fill: var(--color-ice) !important;
}

.header-mobile {
    background:var(--color-bg-muted);
    z-index: 9999;
}

.skp-logo-mobile-svg {
  display: block;
  width: 100%;
  height: auto;
}

.header-mobile .e-con-inner {
    align-items: flex-start;
}

/* Blur + Klicks blocken */
#content.blur-background {
    filter: blur(10px);
    transition: filter 0.3s ease;
    pointer-events: none; /* verhindert Klicks im Content, solange Blur aktiv */
}

/* Scrollen der Seite deaktivieren, solange Menü offen ist */
html.menu-open,
body.menu-open {
    overflow: hidden !important;
}

header #skp-header {
  position: absolute;
  top:0;
  z-index: 99999;
  width: 100%;
  transition: all 0.5s ease;
}

header #skp-header.elementor-sticky--effects {
  top:-200px !important;
}

header #skp-header .skp-logo-container {
  flex: 0 300px;
}

#skp-header a {
  text-decoration: none;
}

/* Navigation / Menu */

/* Basis für die Menü-Links */
.skp-main-nav .elementor-nav-menu .elementor-item.elementor-item-anchor {
  position: relative;
  display: inline-flex;
  align-items: center;
  overflow: visible;
  text-decoration: none;
  transform: scale(1);
  color: var(--color-text);
  transition: all 0.2s ease-out;
}


.skp-main-nav .elementor-nav-menu .elementor-item.elementor-item-anchor:hover {
  color: var(--color-coral);
}


/* Farbige Maske */
.skp-main-nav .elementor-nav-menu .elementor-item.elementor-item-anchor::after {
  content: '&';
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold-extra-bold);
  position: absolute;
  left: -40px;
  display: flex;
  align-items: center;
  padding: inherit;
  box-sizing: border-box;
  color: var(--color-ice);
  transform: translateY(100%);
  opacity: 1;
  filter: blur(0);          /* Wichtig: definierter Ausgangswert */
  pointer-events: none;
  /* falls noch nicht drin: */
  will-change: transform, opacity, filter;
  z-index: -2;
}

/* Keyframes: von unten auf den Text */
@keyframes nav-mask-in {
  0% {
    transform: translateY(100%) scale(1);
    opacity: 0;
    filter: blur(12px);
  }
  10% {
    opacity: 0;
  }
  100% {
    transform: translateY(0%) scale(1);
    opacity: 0.5;
    filter: blur(0);
  }
}

.skp-main-nav .elementor-nav-menu .elementor-item.elementor-item-anchor.mask-anim-in::after {
  animation: nav-mask-in 0.45s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

/* Keyframes: vom Text nach oben raus */
/* --- ANIMATION BEIM VERLASSEN (langsam + fade out) --- */
@keyframes nav-mask-out {
  0% {
    transform: translateY(0%) scale(1);
    opacity: 0.5;
    filter: blur(0);
  }
40% {
    opacity: 0;
    filter: blur(12px);
  }
  100% {
    transform: translateY(-100%) scale(1);
    opacity: 0;
    filter: blur(12px);
  }
}

.skp-main-nav .elementor-nav-menu .elementor-item.elementor-item-anchor.mask-anim-out::after {
  animation: nav-mask-out 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}


#skp-header .skp-main-nav ul li a {
  font-size:var(--font-size-main-nav);
  padding: 20px 25px;
}

/* menu-highlight */

.menu-highlight a, .menu-highlight a:focus, .menu-highlight a:visited {
    background: var(--color-coral);
    padding: 20px 30px 20px 30px;
    color: #FFF !important;
    text-decoration: none;
    border-radius: 50px;
    transform: scale(1);
    font-size: var(--font-size-regular);
    font-weight: var(--font-weight-semibold);
    transition: all 0.3s ease-out;
}

.menu-highlight a:hover {
    background: var(--color-ice);
    border-radius: 15px;
    transform: scale(1.05) !important;
}

.menu-highlight a:after {
    content: '' !important;
}


/* Burger Mobile */

.skp-burger-mobile .elementor-menu-toggle {
  width: 65px;
  height: 65px;
  background-color:var(--color-coral);
  border: 0 solid;
  border-radius: 50px;
  color:#FFF;
  cursor: pointer;
  display: flex;
  font-size: 30px;
  justify-content: center;
  padding: 20px;
  transition: all 0.3s ease-out;
}

.skp-burger-mobile .elementor-menu-toggle.elementor-active {
    border-radius: 10px;
    top: 20px;
    right: 20px;
}

.skp-burger-mobile .elementor-menu-toggle.elementor-active {
  border-radius: 10px;
}

.skp-burger-mobile .elementor-menu-toggle .e-font-icon-svg {
    fill: #FFF;
}

.skp-burger-mobile .elementor-nav-menu--dropdown {
  pointer-events: all;
  border-radius: 25px;
  padding: 80px;
  width: 100%;
  max-width: 800px;
  background: var(--color-coral);
  margin: 0 auto;
}

.skp-burger-mobile .elementor-nav-menu--toggle .elementor-menu-toggle+.elementor-nav-menu__container {
  display: block;
  transform: scaleX(0);
  transform-origin: center center;
  transition: all 0.3s ease-out;
}

.skp-burger-mobile .elementor-nav-menu--toggle .elementor-menu-toggle.elementor-active+.elementor-nav-menu__container {
  transform: scaleX(1);
}

.skp-burger-mobile .elementor-nav-menu--dropdown ul.elementor-nav-menu {
  text-align: center;
}

.skp-burger-mobile .elementor-nav-menu--dropdown ul.elementor-nav-menu li a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.skp-burger-mobile .elementor-nav-menu--dropdown ul.elementor-nav-menu li a {
  color: #FFF;
  font-size: var(--font-size-lg);
  line-height: 1.2;
  background: transparent;
  padding: 20px;
  transition: all 0.3s ease-out;
}

.skp-burger-mobile .elementor-nav-menu--dropdown ul.elementor-nav-menu li a:hover {
  text-decoration: none;
  color: var(--color-ice);
}

.skp-burger-mobile .elementor-nav-menu--dropdown {
  position: fixed;
  left: 20px;
  top: 20%;
  width: calc(100vw - 40px);
}

/* Offset Burger Menu */

.skp-burger-offset {
  display: none;
  width: 100% !important;
  padding: 0;
}

.skp-burger-offset .elementor-nav-menu--toggle {
  padding: 25px;
}

.skp-burger-offset.elementor-sticky--effects {
  display: block;
  width: 100%;
  pointer-events: none;
  background:rgba(178,206,230,0);
  transition: all 0.3s ease-out;
}



.skp-burger-offset.elementor-sticky--effects .elementor-menu-toggle {
  pointer-events: all;
}

.skp-burger-offset.elementor-sticky--effects:has(.elementor-active) {
  height: 100vh;
  background:rgba(178,206,230,0.5);
  pointer-events: none;
}

.skp-burger-offset .elementor-menu-toggle {
  z-index: 99999999;
}

.skp-burger-offset .elementor-nav-menu--toggle {
  position: relative;
  justify-content: center;
  height: 100vh;
}

.skp-burger-offset .elementor-menu-toggle {
  position: absolute;
  top:40px;
  right: 40px;;
  align-items: center;
  background-color:var(--color-coral);
  border: 0 solid;
  border-radius: 50px;
  color:#FFF;
  cursor: pointer;
  display: flex;
  font-size: 30px;
  justify-content: center;
  padding: 20px;
  transition: all 0.3s ease-out;
}

.skp-burger-offset .elementor-menu-toggle:hover {
    border-radius: 10px;
}

.skp-burger-offset .elementor-menu-toggle.elementor-active {
  border-radius: 10px;
}

.skp-burger-offset .elementor-menu-toggle .e-font-icon-svg {
    fill: #FFF;
}

.skp-burger-offset .elementor-nav-menu--dropdown {
  pointer-events: all;
  border-radius: 25px;
  padding: 80px;
  width: 100%;
  max-width: 800px;
  background: var(--color-coral);
  margin: 0 auto;
}

.skp-burger-offset .elementor-nav-menu--toggle .elementor-menu-toggle+.elementor-nav-menu__container {
  display: block;
  transform: scaleX(0);
  transform-origin: center center;
  transition: all 0.3s ease-out;
}

.skp-burger-offset .elementor-nav-menu--toggle .elementor-menu-toggle.elementor-active+.elementor-nav-menu__container {
  transform: scaleX(1);
}

.skp-burger-offset .elementor-nav-menu--dropdown ul.elementor-nav-menu {
  text-align: center;
}

.skp-burger-offset .elementor-nav-menu--dropdown ul.elementor-nav-menu li a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.skp-burger-offset .elementor-nav-menu--dropdown ul.elementor-nav-menu li a {
  color: #FFF;
  font-size: var(--font-size-lg);
  background: transparent;
  padding: 20px;
  transition: all 0.3s ease-out;
}

.skp-burger-offset .elementor-nav-menu--dropdown ul.elementor-nav-menu li a:hover {
  text-decoration: none;
  color: var(--color-ice);
}

/* Ende Burger Menu */

/* Hero Stage */

#hero-stage {
  background-color: var(--color-bg-muted);
  padding-top: 18%;
  padding-bottom: 80px;
  padding-left: 0;
  padding-right: 0;
}

.hero-und-box {
  position: absolute;
  top: 5%;
  left: 7%;
  max-width: 50%;
}

.hero-headline h1 {
  font-size: 7vw;
  line-height: 1.1;
  font-weight: var(--font-weight-bold-extra-bold);
}

.hero-headline span {
  color: var(--color-ice);
}

/* Showcase Slider */

.showcase-slider .showcase-teaser-img {
  border-radius: 35px;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.showcase-slider .showcase-teaser-img:hover {
  border-radius: 15px;
}

#hero-stage .right-aligned-block {
  overflow-x: hidden;
}

#hero-stage .right-aligned-block .e-con-inner .e-child:first-of-type {
  position: relative;
  width: 100vw;
  margin-right: calc((100vw - 80%) / -2);
}

.right-aligned-block {
  overflow-x: hidden;
}

.right-aligned-block .e-con-inner .e-child:first-of-type {
  position: relative;
  width: 100vw;
  margin-right: calc((100vw - 80%) / -2);
}


.showcase-slider .showcase-teaser-img a img {
  transform: scale(1);
  transition: all 0.2s ease-out;
}

.showcase-slider .showcase-teaser-img a:hover img {
  transform: scale(1.03);
}


.showcase-slider .showcase-teaser-img a:after {
  content: '';
  width: 100%;
  height: 100%;
  background: var(--color-coral);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: all 0.3s ease-out;
}

.showcase-slider .showcase-teaser-img a:hover:after {
  opacity: 0.3;
}

.showcase-slider h2 {
  font-size: var(--font-size-h4);
  color: var(--color-coral);
}

.showcase-slider .showcase-tag-wrapper {
  position: absolute;
  flex-direction: row;
  flex-wrap: wrap;
  bottom: 70px;
  left: 15px;
  gap: 10px;
  max-width: 95%;
}

.showcase-slider .showcase-tag-wrapper .showcase-tag {
  font-size: var(--font-size-xs);
  word-break:keep-all;
  color: #FFF;
  padding: 4px 20px;
  border-radius: 20px;
  background: rgba(0,0,0,0.3);
}


.showcase-slider .swiper.elementor-loop-container {
  margin-bottom: 40px;
  padding-bottom: 10px;
}

.showcase-slider  .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: var(--color-coral);
}

#hero-stage .showcase-slider .swiper-pagination.swiper-pagination-progressbar.swiper-pagination-horizontal {
  top:inherit;
  bottom: 0;
  border-radius: 50px;
  overflow: hidden;
}

.showcase-slider .elementor-swiper-button.elementor-swiper-button-next {
  right: calc(100vw - 89.2%) !important;
}

.showcase-slider .elementor-swiper-button {
  background: var(--color-coral);
  height: 80px;
  width: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease-out;
}

.showcase-slider .elementor-swiper-button:hover {
  width: 70px;
}

.showcase-slider .elementor-swiper-button.elementor-swiper-button-prev {
  border-bottom-right-radius: 20px;
  border-top-right-radius: 20px;
}

.showcase-slider .elementor-swiper-button.elementor-swiper-button-prev:hover {
  border-bottom-right-radius: 10px;
  border-top-right-radius: 10px;
}

.showcase-slider .elementor-swiper-button.elementor-swiper-button-next {
  border-bottom-left-radius: 20px;
  border-top-left-radius: 20px;
}

.showcase-slider .elementor-swiper-button.elementor-swiper-button-next:hover {
  border-bottom-left-radius: 10px;
  border-top-left-radius: 10px;
}

.showcase-slider .elementor-swiper-button svg {
  fill: #FFF !important;
}

.showcase-slider .elementor-swiper-button {
  top: 45% !important;
}

/* Startseite  */

.special-bg {
  background: #E63913;
  background: linear-gradient(180deg,rgba(230, 57, 19, 1) 0%, rgba(230, 57, 19, 1) 80%, rgba(255, 255, 255, 0) 80%);
}

/* Service Slider */

.service-slider .service-slide {
  transition: all 0.3s ease-out;
  cursor: pointer;
}

.service-slider .service-slide h2 {
  line-height: var(--line-height-snug);
}

.service-slider .service-slide .service-slide-inner {
  background: #000;
  display: flex;
  flex-direction: column;
  border-radius: 35px;
  height: 70vh;
  justify-content: center;
  align-items: center;
  z-index: 1;
  transition: all 0.3s ease-out;
  overflow: hidden;
}

.service-slider .service-slide:hover {
  width: 400%;
}

.service-slider .service-slide .service-slide-inner:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  background: #000;
  opacity: 0.1;
  transition: all 0.3s ease-out;
}

.service-slider .service-slide .service-slide-inner:hover:after {
  opacity: 0.6;
  transition: all 0.3s ease-out;
}


.service-slider .service-slide .service-slide-inner.brands {
  background: url('https://skpagentur.de/wp-content/uploads/2025/12/service-brands-still.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

.service-slider .service-slide .service-slide-inner.production {
  background: url('https://skpagentur.de/wp-content/uploads/2025/12/service-production-still.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

.service-slider .service-slide .service-slide-inner.print {
  background: url('https://skpagentur.de/wp-content/uploads/2025/12/service-print-still.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

.service-slider .service-slide .service-slide-inner.web {
  background: url('https://skpagentur.de/wp-content/uploads/2025/12/service-web-still.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

.service-slider .service-slide .service-slide-inner.video {
  background: url('https://skpagentur.de/wp-content/uploads/2026/01/service-video-still.jpg');
  background-repeat: no-repeat;
  background-size: cover;
}

.service-slider .service-slide .service-slide-inner .elementor-background-video-container {
  background: #000;
}

.service-slider .service-slide .service-slide-inner .elementor-background-video-container {
  opacity: 0;
}

.service-slider .service-slide .service-slide-inner:hover .elementor-background-video-container {
  opacity: 1;
}

.service-slider .service-slide .service-slide-inner:hover .elementor-background-video-container video {
  filter: blur(2px);
}

.service-slider .service-slide .service-slide-inner h2 {
  font-size: var(--font-size-xl);
  text-align: center;
  transform: rotate(-90deg);
  color: #fff;
  transition: all 0.3s ease-out;
}

.service-slider .service-slide .service-slide-inner .elementor-widget-heading, .service-slider .service-slide .service-slide-inner .elementor-widget-text-editor {
  z-index: 3;
}

.service-slider .service-slide:hover .service-slide-inner h2 {
  font-size: var(--font-size-xl);
  transform: rotate(0);
  color: #fff;
}

.service-slider .service-slide .service-slide-inner ul {
  color: #FFF;
  display: none;
  transform: translateY(50%);
  transition: all 0.3s ease-out;
  list-style: none;
  text-align: center;
  padding: 0;
}

.service-slider .service-slide .service-slide-inner ul li {
  font-size: var(--font-size-lg);
  margin-bottom: 15px;
}

.service-slider .service-slide:hover .service-slide-inner ul {
  display: inherit;
  transform: translateY(0);
}

/* sections */

.et-bg {
  background: url();
}

/* Grundstil des Custom-Cursors */
/* Basis-Cursor */
.custom-cursor {
  position: fixed;
  top: 0;
  left: 0;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 9999;
  opacity: 0;
  transition: opacity 0.2s ease, transform 0.15s ease;
  font-family: inherit;
}

.custom-cursor span {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.85); /* Fallback */
  color: #fff;
  font-size: 12px;
  white-space: nowrap;
}

/* Sichtbar */
.custom-cursor.is-visible {
  opacity: 1;
}

/* Leichte Bewegungsanimation */
.custom-cursor.is-moving {
  transform: translate(-50%, -50%) scale(1.03);
}


/* 🔹 Stil für "Projekt ansehen" */
.custom-cursor.cursor-style-projekt span {
  background:var(--color-coral);      /* z.B. dunkles Anthrazit */
  color: #ffffff;
  border: none;
  padding: 10px 15px;
  font-size: var(--font-size-regular);
}

/* 🔹 Stil für "Kontakt aufnehmen" */
.custom-cursor.cursor-style-contact span {
  background: #2563eb;      /* z.B. Blau */
  color: #ffffff;
  /* hier kannst du auch alles anpassen: */
  /* border-radius: 6px; */
  /* font-weight: 600; */
}

#cursorTrailContainer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: visible;
  z-index: 9998;
}

/* Basis für Trail-Partikel */
.cursor-trail-dot {
  position: fixed;
  pointer-events: none;
  transform: translate(-50%, -50%) scale(1.8);
  animation: trail-fade 1.8s forwards;
  filter: blur(0); /* macht es weicher */
}

/* Verschiedene "organische" Formen über border-radius */
.cursor-trail-dot.organic-1 {
  border-radius: 60% 40% 55% 45% / 40% 60% 40% 60%;
}

.cursor-trail-dot.organic-2 {
  border-radius: 45% 55% 65% 35% / 55% 45% 35% 65%;
}

.cursor-trail-dot.organic-3 {
  border-radius: 70% 30% 50% 50% / 40% 70% 30% 60%;
}

/* Standardfarbe – kannst du natürlich an deine CI anpassen */
.cursor-trail-dot {
  /*
  background: rgba(230, 57, 19, 0.35);
  */
  background: rgba(83, 160, 248, 0.55);
}

/* Fade / Shrink Animation */
@keyframes trail-fade {
  to {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.4);
  }
}

/* Galleries */

.skp-img-gal img {
  border-radius: 35px;
  overflow: hidden;
}

/* Kunden / Logos */

.skp-kunden .elementor-image-carousel-wrapper {
  padding-left: 1px;
}

.skp-kunden .swiper-slide {
  display: flex;
  padding: 40px;
  border: 1px solid var(--color-border);
  aspect-ratio: 2 / 1;
  flex-direction: column;
  justify-content: center;
  border-radius: 25px;
  transition: all 0.3s ease-out;
}

.skp-kunden .swiper-slide figure {
  display: flex;
  justify-content: center;
  max-height: 100%;
}


.skp-kunden .swiper-slide figure img {
  filter: saturate(0);
  transition: all 0.3s ease-out;
}

.skp-kunden .swiper-slide:hover {
  border-radius: 10px;
}

.skp-kunden .swiper-slide:hover figure img  {
  filter: saturate(1);
}

/* Standards */

.standard-head {
  background: var(--color-bg-muted);
  padding: 14% 0 2% 0;
}

.skp-hero-img {
  padding: 20% 0 2% 0;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
}

/* Showcases */
.showcase-single-head {
  background: var(--color-bg-muted);
  padding-top: 15%;
  padding-bottom: 2%;
  margin-bottom: 4%;
  padding-left: 0;
  padding-right: 0;
}

.showcase-single-head:after, .standard-head:after {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  content: '';
  background: url('https://skpagentur.de/wp-content/uploads/2025/12/et-stroke-ice.svg');
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center right;
  background-attachment: fixed;
  opacity: 0.3;
  z-index: 1;
}

.showcase-single-head .e-con-inner, .standard-head .e-con-inner {
  z-index: 2;
}



.showcase-meta-container {
  justify-content: flex-end;
  border-left: 2px solid var(--color-coral);
  padding-left: 1%;
}

.showcase-meta {
  gap: 5px;
}

.single-showcase-tag-container {
  gap: 0;
  flex-wrap:wrap;
}

.showcase-meta-services .single-showcase-tag {
  display: flex;
  gap: 0;
}


.showcase-meta-services .single-showcase-tag:after {
  content:',';
  margin-right: 5px;
}

.showcase-meta-services .single-showcase-tag:last-of-type:after {
  content:'';
  margin-right: 0;
}


.showcase-meta h2 {
  font-size: var(--font-size-regular);
}

.single-showcase-tag {
  font-size: var(--font-size-sm);
}

.showcase-gallery .e-gallery-item {
  overflow: hidden;
  border-radius: 35px;
  transition: all 0.3s ease-out;
}

.showcase-gallery a, .showcase-gallery video {
  overflow: hidden;
  border-radius: 35px;
  transition: all 0.3s ease-out;
  width: 100%;
  max-width: 100%;
}

.showcase-gallery .e-gallery-item:hover, .showcase-gallery a:hover, .showcase-gallery video:hover {
  border-radius: 15px;
}

.showcase-gallery .elementor-gallery-item:hover .elementor-gallery-item__overlay {
  background:var(--color-coral);
  background-color: var(--color-coral) !important;
  opacity: 0.2;
}

.showcases-single-caroussel-wrapper {
  border-top: 2px solid var(--color-coral);
  padding-top: 2%;
  background: var(--color-bg-muted);
}

.showcases-single-caroussel .e-loop-item .e-con-inner {
  margin-left: 0;
  margin-right: 0;
  width: 100%;
  max-width: 100%;
}

.showcases-single-caroussel .e-loop-item .e-con-inner .elementor-widget-image {
  border-radius: 25px;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.showcases-single-caroussel .e-loop-item .e-con-inner .elementor-widget-image:hover {
  border-radius: 10px;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.showcase-slider-single h2 {
  font-size: var(--font-size-regular);
  color: var(--color-text);
}

.showcases-teaser-single-wrapper {
  border-top: 2px solid var(--color-coral);
  padding-top: 25px;
}

/* Kontakt */

.elementor-popup-modal.skp-contact-overlay .dialog-widget-content {
  max-width: 95%;
  max-height: 95%;
  overflow: hidden;
  background: var(--color-coral);
}

.elementor-popup-modal.skp-contact-overlay .dialog-widget-content h2 {
  color: #FFF;
}

.elementor-popup-modal.skp-contact-overlay .dialog-widget-content p {
  color: #FFF;
  font-size: var(--font-size-sm);
}

.elementor-popup-modal.skp-contact-overlay .dialog-widget-content p {
  margin-bottom: 5px;
}

.elementor-popup-modal.skp-contact-overlay a.dialog-close-button svg {
  fill: #FFF !important;
  transform: rotate(0);
  transition: all 0.3s ease-out;
}

.elementor-popup-modal.skp-contact-overlay a.dialog-close-button:hover svg {
  transform: rotate(90deg);
  fill:var(--color-ice) !important;
}

/* Kontakt Formular */

.skp-contact-form label {
  display: none;
}

.skp-contact-form .elementor-field-group input, .skp-contact-form .elementor-field-group textarea {
  border: 0;
  padding: 15px;
  background: transparent;
  border-bottom: 1px solid #FFF;
  font-size: 20px;
  line-height: 1.2;
  border-radius: 0;
}

.elementor-field-group .elementor-field-textual:focus {
  box-shadow: none !important;
  border-bottom: 1px solid #000;
}

.skp-contact-form .elementor-field-group.elementor-field-type-submit {
  width: auto;
}

.skp-contact-form::placeholder {
  opacity: 1 !important;
  color: #FFF !important;
}

.skp-contact-form .elementor-field-group.elementor-field-type-submit button {
  background: #FFF;
  padding: 20px 30px 25px 30px;
  color: var(--color-coral) !important;
  text-decoration: none;
  border-radius: 50px;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  margin-top: 20px;
  transition: all 0.3s ease-out;
}

.skp-contact-form .elementor-field-group.elementor-field-type-submit button:hover {
  border-radius: 15px;
  transform: scale(1.05);
  color: var(--color-coral);
}

.skp-contact-form .elementor-message {
  color: #FFF;
}

.skp-contact-form .elementor-message-svg:before {
    background-image: none !important;
    content: "😊";
    height: 1em;
    width: 1em;
}


/* Form Asbildung */

/* Kontakt Formular Form */

.skp-form .elementor-field-group input, .skp-form .elementor-field-group textarea {
  transition: all 0.3s ease-out;
  padding: 7px 20px 7px 0;
}

.skp-form .elementor-field-group input:focus, .skp-form .elementor-field-group textarea:focus {
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  outline: 0 none;
  border-bottom: 1px solid #333333 !important;
}

.skp-form input[type="text"], .skp-form input[type="Email"] {
  background-color: transparent !important;
  background: transparent !important;
  border-color: #FFF !important;
}

.skp-form input[type="checkbox"] {
  width: 15px;
  height:15px;
}

.skp-form .elementor-field-group .elementor-field-textual {
    color: #FFF;
    font-size: var(--font-size-regular);
    font-weight: var(--font-weight-light);
    border-color: #FFF;
}

.elementor-field-type-html:has(.ausbildung-form-formal) {
  margin-bottom: 0 !important;
}

.skp-form .elementor-field-type-upload input {
  color: #FFF;
}

.skp-form .ausbildung-form-caption {
    color: #FFF;
}

.skp-form .ausbildung-form-formal {
    color: #FFF;
    font-size: var(--font-size-sm);
    line-height: var(--line-height-normal);
}

.skp-form .elementor-field-type-acceptance .elementor-field-option {
  display: flex;
  gap: 10px;
}

.skp-form .elementor-field-type-acceptance input[type="checkbox"] {
  width: 25px;
  height: 25px;
  flex-shrink: 0;
}

.skp-form textarea::placeholder, .skp-form input::placeholder {
  color: rgba(255, 255, 255, 1) !important;
  opacity: 1 !important;
}

.skp-form-container h2 {
  margin-bottom: 20px;
}

.skp-form #skp-form-button-submit {
  background: #FFF;
  padding: 20px 30px 25px 30px;
  color: var(--color-coral);
  text-decoration: none;
  border-radius: 50px;
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  transition: all 0.3s ease-out;
}

.skp-form #skp-form-button-submit:hover {
  border-radius: 15px;
  transform: scale(1.05);
  color: var(--color-coral);
}




/* Footer */

footer {
  position: relative;
}

.skp-footer-menu ul {
  flex-direction: column;
  gap: 20px;
}

.skp-footer-menu ul li a {
  font-size: var(--font-size-lg);
  text-decoration: none;
}

.skp-footer-menu ul li a:hover {
  color: var(--color-coral);
  text-decoration: none;
}

.skp-footer-menu ul li.menu-highlight a {
  font-size: var(--font-size-lg);
  background: var(--color-coral);
  padding: 20px;
  color: #FFF;
  text-decoration: none;
  border-radius: 35px;
  transition: all 0.3s ease-out;
}

.skp-footer-menu ul li.menu-highlight a:hover, .skp-footer-menu ul li.menu-highlight a:active, .skp-footer-menu ul li.menu-highlight a:visited {
  font-size: var(--font-size-lg);
  padding: 20px;
  border-radius: 15px;
}

.skp-footer-logo svg {
  width: 300px;
  max-width: 300px;
}

.footer-ani-box {
  justify-content: flex-end;
  overflow: hidden;
  height: 100vh;
  padding: 0;
  position: absolute;
  bottom: 0;
  pointer-events:none;
}

.footer-ani-box-wrapper {
  position: absolute;
  bottom: 0;
}

.floating-amps {
  position: relative;
  width: 100%;
  height: 200px;
}

.floating-amps .amp {
  font-weight: var(--font-weight-bold-extra-bold);
}

.floating-amps .amp-one {
  position: absolute;
  bottom: -268%;
  left: 11%;
  font-size: 38vw;
  color: var(--color-text);
  opacity: 0.1;
}

.floating-amps .amp-two {
  position: absolute;
  opacity: 0.3;
  bottom: -277%;
  left: -6%;
  font-size: 37vw;
  color: var(--color-coral);
}

.floating-amps .amp-three {
  position: absolute;
  opacity: 0.6;
  bottom: -277%;
  left: 24%;
  font-size: 42vw;
  color: var(--color-ice);
}

.floating-amps .amp-four {
  position: absolute;
    opacity: 1;
    bottom: -204%;
    left: 44%;
    font-size: 34vw;
    color: var(--color-bg-muted);
}

.floating-amps .amp-five {
  position: absolute;
    opacity: 0.6;
    bottom: -277%;
    left: 60%;
    font-size: 32vw;
    color: var(--color-coral);
}

.floating-amps .amp-six {
  position: absolute;
    opacity: 0.7;
    bottom: -326%;
    left: 78%;
    font-size: 41vw;
    color: var(--color-bg-muted);
}

.floating-amps span {
  display: inline-block;
  animation: float 4s ease-in-out infinite;
}

/* leichte Variation pro Zeichen — wirkt natürlicher */
.floating-amps .amp-one {
  animation-duration: 5s;
}
.floating-amps .amp-two {
  animation-duration: 6s;
}
.floating-amps .amp-three {
  animation-duration: 3s;
}
.floating-amps .amp-four {
  animation-duration: 7s;
}
.floating-amps .amp-five {
  animation-duration: 4s;
}

@keyframes float {
  0%   { 
    transform: translateY(0);
    filter: blur(10px);
  }
  50%  { 
    transform: translateY(-60px);
    filter: blur(40px);
  }
  100% { 
    transform: translateY(0); 
    filter: blur(10px);
  }
}

.footer-formal {
  position: absolute;
  bottom: 20%;
}

.footer-formal-wrapper {
  display: flex;
  justify-content: center;
}

.footer-formal .footer-formal-wrapper .footer-company, .footer-formal .footer-formal-wrapper a {
  color: var(--color-text);
  font-size: var(--font-size-sm);
  line-height: 1;
  transition: all 0.3s ease-out;
  text-decoration: none;
}

.footer-formal .footer-company, .footer-formal .footer-formal-nav {
  align-content: center;
  display: flex;
}

.footer-formal .footer-company:after {
  content: '|';
  margin-left: 8px;
  margin-right: 8px;
  color: var(--color-coral);
  margin-top: -2px;
}

.footer-formal .footer-formal-nav a {
  margin-left: 15px;
}

.footer-formal .footer-formal-nav a:first-of-type {
  margin-left: 0;
}

.footer-formal .footer-formal-wrapper a:hover {
  color: var(--color-coral);
}

footer .footer-adress p {
  font-size: var(--font-size-sm);
}

footer .footer-adress a {
  text-decoration: none;
  transition: all 0.3s ease-out;
}

footer .footer-adress a:hover {
  text-decoration: none;
  color: var(--color-coral);
}

.social-media-wrapper a {
  border-radius: 50px;
  overflow: hidden;
  transition: all 0.3s ease-out;
}

.social-media-wrapper a:hover {
  border-radius: 15px;
}

.social-media-wrapper img {
  width: 65px !important;
  height: 65px !important;
  background: var(--color-coral);
  padding: 15px;
}


/* Top Button */

.top-button-cont {
  position:fixed;
  width: 60px;
  height: 60px;
  right:20px;
  bottom:20px;
  z-index:9999999;
  padding: 0 !important;
}

.top-button-cont .e-con-inner {
  padding: 0 !important;
}

.topbutton {
     height:60px;
     width:60px;
     padding: 12px;
     border-radius: 50px;
     background-color:var(--color-coral);
     content: url("data/back-to-top.svg");
     transition: all 0.4s ease-out;
     z-index: 999999;
}

.topbutton:hover {
  border-radius: 10px;
}

