/*
 Theme Name:   GeneratePress Child
 Theme URI:    https://generatepress.com
 Description:  Default GeneratePress child theme
 Author:       Tom Usborne
 Author URI:   https://tomusborne.com
 Template:     generatepress
 Version:      0.1
*/
/* Listing Styles */
/* Stackable Block Schatten entfernen */

/* Nuclear Option - entfernt ALLES */

.linkor a{color:#cc3c1d; text-decoration:none;}
.linkor a:hover{color:#cc3c1d; text-decoration:underline;}

.orbit-container {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 600px;
  padding: 40px;
}

.orbit-animation {
  position: relative;
  width: 500px;
  height: 500px;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* Mittlerer Kreis mit TY Text */
.center-circle {
  position: absolute;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3a3a3a 0%, #2a2a2a 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10;
  box-shadow: 0 0 40px rgba(255, 255, 255, 0.1);
}

.center-circle::before {
  content: '';
  position: absolute;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: #ffffff;
  z-index: -1;
}

.center-text {
  font-size: 48px;
  font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 2px #ff4b24;
  text-stroke: 2px #ff4b24;
  letter-spacing: -2px;
  z-index: 1;
}

/* Orbit Ringe */
.orbit-ring {
  position: absolute;
  border: 1px solid #474747;
  border-radius: 50%;
  pointer-events: none;
}

.inner-ring {
  width: 300px;
  height: 300px;
  animation: rotate 25s linear infinite;
}

.outer-ring {
  width: 460px;
  height: 460px;
  animation: rotate 35s linear infinite reverse;
}

/* Orbit Icons */
.orbit-icon {
  position: absolute;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3a3a3a 0%, #2a2a2a 100%);
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  color: #ffffff;
  z-index: 8;
  transition: color 0.3s ease;
}

.orbit-icon svg {
  width: 26px;
  height: 26px;
}

/* Icon 1 - Photo */
.icon-1 {
  animation: orbitRotate1 25s linear infinite, pulsate1 10s ease-in-out infinite;
}

/* Icon 2 - Stativ */
.icon-2 {
  animation: orbitRotate2 25s linear infinite, pulsate2 10s ease-in-out infinite;
}

/* Icon 3 - Beleuchtung */
.icon-3 {
  animation: orbitRotate3 35s linear infinite reverse, pulsate3 10s ease-in-out infinite;
}

/* Icon 4 - Drohne */
.icon-4 {
  animation: orbitRotate4 35s linear infinite reverse, pulsate4 10s ease-in-out infinite;
}

/* Icon 5 - Mikrofon */
.icon-5 {
  animation: orbitRotate5 35s linear infinite reverse, pulsate5 10s ease-in-out infinite;
}

/* Animations */
@keyframes rotate {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Icon Rotationen */
@keyframes orbitRotate1 {
  from { transform: rotate(0deg) translateX(150px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(150px) rotate(-360deg); }
}

@keyframes orbitRotate2 {
  from { transform: rotate(180deg) translateX(150px) rotate(-180deg); }
  to { transform: rotate(540deg) translateX(150px) rotate(-540deg); }
}

@keyframes orbitRotate3 {
  from { transform: rotate(0deg) translateX(230px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(230px) rotate(-360deg); }
}

@keyframes orbitRotate4 {
  from { transform: rotate(120deg) translateX(230px) rotate(-120deg); }
  to { transform: rotate(480deg) translateX(230px) rotate(-480deg); }
}

@keyframes orbitRotate5 {
  from { transform: rotate(240deg) translateX(230px) rotate(-240deg); }
  to { transform: rotate(600deg) translateX(230px) rotate(-600deg); }
}

/* Pulsier-Animationen mit orangenem Schatten UND Farbwechsel - nacheinander */

/* Photo (Icon 1) - zuerst */
@keyframes pulsate1 {
  0%, 5% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
  8% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  12% {
    box-shadow: 0 0 20px rgba(255, 75, 36, 0.6), 0 0 40px rgba(255, 75, 36, 0.3);
    color: #ff4b24;
  }
  18% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  20%, 100% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
}

/* Stativ (Icon 2) - zweiter */
@keyframes pulsate2 {
  0%, 20% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
  23% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  28% {
    box-shadow: 0 0 20px rgba(255, 75, 36, 0.6), 0 0 40px rgba(255, 75, 36, 0.3);
    color: #ff4b24;
  }
  38% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  40%, 100% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
}

/* Drohne (Icon 4) - dritter */
@keyframes pulsate4 {
  0%, 40% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
  43% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  48% {
    box-shadow: 0 0 20px rgba(255, 75, 36, 0.6), 0 0 40px rgba(255, 75, 36, 0.3);
    color: #ff4b24;
  }
  58% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  60%, 100% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
}

/* Mikrofon (Icon 5) - vierter */
@keyframes pulsate5 {
  0%, 60% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
  63% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  68% {
    box-shadow: 0 0 20px rgba(255, 75, 36, 0.6), 0 0 40px rgba(255, 75, 36, 0.3);
    color: #ff4b24;
  }
  78% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  80%, 100% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
}

/* Beleuchtung (Icon 3) - fünfter */
@keyframes pulsate3 {
  0%, 80% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
  83% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  88% {
    box-shadow: 0 0 20px rgba(255, 75, 36, 0.6), 0 0 40px rgba(255, 75, 36, 0.3);
    color: #ff4b24;
  }
  98% {
    box-shadow: 0 0 30px rgba(255, 75, 36, 0.8), 0 0 50px rgba(255, 75, 36, 0.5);
    color: #ff4b24;
  }
  100% {
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
    color: #ffffff;
  }
}

/* Tablet */
@media (max-width: 1024px) {
  .orbit-animation {
    width: 400px;
    height: 400px;
  }
  
  .center-circle {
    width: 120px;
    height: 120px;
  }
  
  .center-circle::before {
    width: 100px;
    height: 100px;
  }
  
  .center-text {
    font-size: 40px;
    -webkit-text-stroke: 1.8px #ff4b24;
    text-stroke: 1.8px #ff4b24;
  }
  
  .inner-ring {
    width: 240px;
    height: 240px;
  }
  
  .outer-ring {
    width: 360px;
    height: 360px;
  }
  
  .orbit-icon {
    width: 45px;
    height: 45px;
  }
  
  .orbit-icon svg {
    width: 22px;
    height: 22px;
  }
  
  @keyframes orbitRotate1 {
    from { transform: rotate(0deg) translateX(120px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(120px) rotate(-360deg); }
  }
  
  @keyframes orbitRotate2 {
    from { transform: rotate(180deg) translateX(120px) rotate(-180deg); }
    to { transform: rotate(540deg) translateX(120px) rotate(-540deg); }
  }
  
  @keyframes orbitRotate3 {
    from { transform: rotate(0deg) translateX(180px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(180px) rotate(-360deg); }
  }
  
  @keyframes orbitRotate4 {
    from { transform: rotate(120deg) translateX(180px) rotate(-120deg); }
    to { transform: rotate(480deg) translateX(180px) rotate(-480deg); }
  }
  
  @keyframes orbitRotate5 {
    from { transform: rotate(240deg) translateX(180px) rotate(-240deg); }
    to { transform: rotate(600deg) translateX(180px) rotate(-600deg); }
  }
}

/* Mobile */
@media (max-width: 480px) {
  .orbit-container {
    min-height: 400px;
    padding: 20px;
  }
  
  .orbit-animation {
    width: 300px;
    height: 300px;
  }
  
  .center-circle {
    width: 90px;
    height: 90px;
  }
  
  .center-circle::before {
    width: 75px;
    height: 75px;
  }
  
  .center-text {
    font-size: 32px;
    -webkit-text-stroke: 1.5px #ff4b24;
    text-stroke: 1.5px #ff4b24;
  }
  
  .inner-ring {
    width: 180px;
    height: 180px;
  }
  
  .outer-ring {
    width: 270px;
    height: 270px;
  }
  
  .orbit-icon {
    width: 38px;
    height: 38px;
  }
  
  .orbit-icon svg {
    width: 18px;
    height: 18px;
  }
  
  @keyframes orbitRotate1 {
    from { transform: rotate(0deg) translateX(90px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(90px) rotate(-360deg); }
  }
  
  @keyframes orbitRotate2 {
    from { transform: rotate(180deg) translateX(90px) rotate(-180deg); }
    to { transform: rotate(540deg) translateX(90px) rotate(-540deg); }
  }
  
  @keyframes orbitRotate3 {
    from { transform: rotate(0deg) translateX(135px) rotate(0deg); }
    to { transform: rotate(360deg) translateX(135px) rotate(-360deg); }
  }
  
  @keyframes orbitRotate4 {
    from { transform: rotate(120deg) translateX(135px) rotate(-120deg); }
    to { transform: rotate(480deg) translateX(135px) rotate(-480deg); }
  }
  
  @keyframes orbitRotate5 {
    from { transform: rotate(240deg) translateX(135px) rotate(-240deg); }
    to { transform: rotate(600deg) translateX(135px) rotate(-600deg); }
  }
}






















.linki a{color:#626262;text-decoration:none;}
.linki a:hover{color:#626262;text-decoration:underline;}
.linki1 a{color:#2a2a2a;text-decoration:none;}
.linki1 a:hover{color:#2a2a2a;text-decoration:underline;}
.red-glow {
  position: relative !important;
  display: inline-block !important;
  overflow: hidden !important;
}

.red-glow img {
  filter: brightness(0.35) contrast(1.1) !important;
  display: block !important;
  width: 100% !important;
  transition: filter 0.4s ease !important;
}

.red-glow::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  width: 70% !important;
  height: 100% !important;
  background: radial-gradient(ellipse at right center, 
    rgba(255, 90, 40, 0.7) 0%, 
    rgba(255, 110, 60, 0.5) 20%, 
    rgba(220, 80, 50, 0.3) 40%, 
    rgba(180, 60, 40, 0.15) 60%, 
    transparent 80%) !important;
  pointer-events: none !important;
  z-index: 1 !important;
  transition: opacity 0.4s ease !important;
}

.red-glow::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(to right, 
    rgba(0, 0, 0, 0.6) 0%, 
    transparent 50%) !important;
  pointer-events: none !important;
  z-index: 0 !important;
  transition: opacity 0.4s ease !important;
}

/* Hover - Bild wird klar */
.red-glow:hover img {
  filter: brightness(1) contrast(1) !important;
}

.red-glow:hover::after,
.red-glow:hover::before {
  opacity: 0 !important;
}

/* Mobile - Immer klar */
@media (max-width: 768px) {
  .red-glow img {
    filter: brightness(1) contrast(1) !important;
  }
  
  .red-glow::after,
  .red-glow::before {
    display: none !important;
  }
}
.site-footer {display:none;}
.backi {
  background: 
    linear-gradient(to top, #020202 0%, transparent 20%),
    linear-gradient(to bottom, #020202 0%, transparent 20%),
    linear-gradient(135deg, #0a0a0a 0%, #151515 50%, #1f1f1f 100%);
}





.text-mit-linie {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
  margin-top: 8em !important;
  margin-bottom: 4em !important;
}

.text-mit-linie::after {
  content: "" !important;
  flex: 1 !important;
  height: 1px !important;
  background-color: #626262 !important;
  margin-left: 20px !important;
}

.text-box {
  display: inline-block !important;
  color: #fff !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  border: 1px solid #626262 !important;
  border-radius: 25px !important;
  padding: 4px 15px !important;
  white-space: nowrap !important;
}

/* Tablet */
@media (max-width: 1024px) {
  .text-mit-linie {
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-top: 5em !important;
    margin-bottom: 5em !important;
  }
  
  .text-mit-linie::after {
    margin-left: 15px !important;
  }
  
  .text-box {
    padding: 6px 12px !important;
    font-size: 14px !important;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .text-mit-linie {
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-top: 3em !important;
    margin-bottom: 3em !important;
  }
  
  .text-mit-linie::after {
    margin-left: 10px !important;
    min-width: 30px !important;
  }
  
  .text-box {
    font-size: 13px !important;
    padding: 5px 10px !important;
  }
}






.pill-container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  flex-wrap: nowrap !important;
  margin-top: 8em !important;
  margin-bottom: 1em !important;
}

.pill-text {
  display: inline-block !important;
  color: #fff !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  border: 1px solid #626262 !important;
  border-radius: 25px !important;
  padding: 4px 15px !important;
  white-space: nowrap !important;
}

/* Tablet */
@media (max-width: 1024px) {
  .pill-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-top: 5em !important;
    margin-bottom: 1em !important;
  }
  
  .pill-text {
    padding: 6px 12px !important;
    font-size: 14px !important;
  }
}

/* Mobile */
@media (max-width: 480px) {
  .pill-container {
    padding-left: 20px !important;
    padding-right: 20px !important;
    margin-top: 3em !important;
    margin-bottom: 1em !important;
  }
  
  .pill-text {
    font-size: 13px !important;
    padding: 5px 10px !important;
  }
}





.image-dark {filter: brightness(0.55) contrast(1.1);}


.text-linie1::after {
    content: "" !important;
    flex: 1 !important;
    height: 1px !important;
    background-color: #626262 !important;
    margin-left: 20px !important;
}

.text-linie1 {
    display: flex !important;
    align-items: center !important;
    color: #000 !important;
    width: 100% !important;
    flex-wrap: nowrap !important;
    font-size: 15px !important;
	text-transform:uppercase !important;
}

@media (max-width: 768px) {
    .text-linie1::after {
        margin-left: 15px !important;
    }
}

@media (max-width: 480px) {
    .text-linie1::after {
        margin-left: 10px !important;
        min-width: 30px !important;
    }
    
    .text-linie1 {
        font-size: 0.9em !important;
    }
}




/* GeneratePress Menu Styling */
.menu.sf-menu {
  background: rgba(255, 255, 255, 0.15); /* Heller gemacht */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 50px;
  padding: 4px 15px;
}

.menu.sf-menu li a {
  color: #ffffff;
  position: relative;
  overflow: hidden;
  transition: color 0.4s ease, background 0.4s ease;
  border-radius: 25px;
  padding: 2px 15px;
}

/* Erster Menüpunkt - Links komplett abgerundet */
.menu.sf-menu > li:first-child a {
  border-radius: 50px 50px 50px 50px;
  margin-left: -11px;
  padding-left: 32px;
  margin-right: -15px;
  padding-right: 30px;
}

/* Letzter Menüpunkt - Rechts komplett abgerundet */
.menu.sf-menu > li:last-child a {
  border-radius: 50px 50px 50px 50px;
  margin-right: -11px;
  padding-right: 26px;
  margin-left: -15px;
  padding-left: 30px;
}

/* Wellen-Effekt beim Hover */
.menu.sf-menu li a::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  transform: translate(-50%, -50%);
  transition: width 0.6s ease, height 0.6s ease;
}

.menu.sf-menu li a:hover {
  color: #888888;
  background: rgba(255, 255, 255, 0.1); /* Heller gemacht */
}

.menu.sf-menu li a:hover::before {
  width: 300px;
  height: 300px;
}

/* Dropdown-Menü auch stylen */
.menu.sf-menu ul {
  background: rgba(255, 255, 255, 0.15); /* Heller gemacht */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 20px;
}

.menu.sf-menu ul li a:hover {
  background: rgba(255, 255, 255, 0.1); /* Heller gemacht */
  border-radius: 15px;
}

/* Mobile Menü - Als Overlay über allem */
@media (max-width: 768px) {
  /* Header bleibt an Ort und Stelle */
  .site-header {
    position: fixed !important;
    top: 0 !important;
    width: 100% !important;
    z-index: 9999 !important;
  }
  
  /* Hamburger/X Button stylen */
  .menu-toggle,
  button.menu-toggle {
    position: fixed !important;
    top: 20px !important;
    right: 20px !important;
    z-index: 10000 !important;
    background: rgba(255, 255, 255, 0.2) !important; /* Heller gemacht */
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    border-radius: 50% !important;
    width: 50px !important;
    height: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  .menu-toggle .gp-icon,
  .menu-toggle svg {
    color: #ffffff !important;
    fill: #ffffff !important;
  }
  
  /* Menü als Overlay */
  .main-navigation.toggled,
  .main-navigation.toggled .main-nav {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100vh !important;
    background: rgba(255, 255, 255, 0.1) !important; /* Heller gemacht */
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    z-index: 9998 !important;
    overflow-y: auto !important;
    padding-top: 80px !important;
  }
  
  /* Alle Header-Elemente transparent */
  .site-header,
  .inside-header,
  .mobile-bar,
  .mobile-menu-control-wrapper {
    background-color: transparent !important;
    background-image: none !important;
    background: transparent !important;
  }
  
  /* Menü selbst */
  .menu.sf-menu {
    background: transparent;
    border-radius: 0;
    padding: 20px;
  }
  
  .menu.sf-menu li {
    margin-bottom: 10px;
  }
  
  .menu.sf-menu li a {
    border-radius: 0;
    padding: 15px 20px;
    display: block;
    background: rgba(255, 255, 255, 0.15); /* Heller gemacht */
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  
  .menu.sf-menu > li:first-child a,
  .menu.sf-menu > li:last-child a {
    border-radius: 0;
    margin: 0;
    padding: 15px 20px;
  }
  
  .menu.sf-menu ul {
    background: transparent;
    border-radius: 0;
  }
  
  .menu.sf-menu ul li a {
    background: rgba(255, 255, 255, 0.12); /* Heller gemacht */
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  
  .menu.sf-menu ul li a:hover {
    border-radius: 0;
  }
}

/* Tablet spezifische Optimierungen */
@media (min-width: 769px) and (max-width: 1024px) {
  .menu.sf-menu {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  
  .menu.sf-menu ul {
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
}