/*
Theme Name: GeneratePress Child
Template: generatepress
*/

/* --- Basis Header Layout --- */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 24px 24px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

/* Header inner: drei Zonen */
.site-header .inside-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
}

/* Hauptmenu absolut zentrieren */
.main-navigation {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-navigation .main-nav li {
  margin-right: clamp(16px, 3vw, 40px);
}

.main-navigation .main-nav li:last-child {
  margin-right: 0;
}

.main-navigation a, .contact-menu a {
  font-size: clamp(18px, 1.8vw, 24px);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  padding: 8px 16px;
  position: relative;
  transition: color 0.3s ease;
}

.main-navigation a::after, .contact-menu a::after {
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--accent-yellow, #c0a060);
  transition: width 0.3s ease;
}

.main-navigation .main-nav ul li a::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent-yellow, #c0a060), transparent);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease, opacity 0.3s ease;
}

.main-navigation .main-nav ul li a:hover::after {
  transform: scaleX(1);
  opacity: 1;
}

/* Kontaktmenu absolut rechts */
.contact-menu {
	top: -1px;
}

.contact-menu a {
  font-weight: 600;  
	color: var(--light-background);
  padding: 30px 70px;     
  transition: background-color 0.3s ease, color 0.3s ease;
}

.contact-menu a::after {
  content: "";
  position: absolute;
  bottom: 8px; 
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent-yellow, #c0a060), transparent);
  opacity: 0;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease, opacity 0.3s ease;
}

.contact-menu a:hover::after {
  transform: scaleX(1);
  opacity: 1;
}

/* --- Responsive: auf Mobil reduziert stacked --- */
@media (max-width: 980px) {
  .main-navigation { position: static; transform:none; margin: 8px 0; }
  .site-header .inside-header { flex-direction: row; justify-content: space-between; }
  .site-header { padding:12px 12px; }
}
.conctact-menu {
	top: 12px;
	right: 12px;
}
@media (max-width: 600px) {
  .site-branding img { max-width: 120px; }
}

.grid-container, .wp-block-group__inner-container {
	max-width:100%;
}

.one-container .site-content {
    padding: 0px;
}

.site-main .wp-block-group__inner-container {
  padding: 0;
	margin: 0;
	width: 100%;
}

.hero-block, .erkunde-block {
  margin-left: 0px !important;
  margin-right: 0px !important;
}

.hero-header {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top:100px;
}

.hero-shot figure {
    max-width: 100% !important;
	  width: 100%;
}

.hero-shot figure img {
    width: 100%;
    height: 100%;
}

.hero-shot {
  filter: blur(25px);
  opacity: 0.6;
  animation: heroFadeIn 4s ease-out forwards;
}

@keyframes heroFadeIn {
  0% {
    filter: blur(25px);
  }
  100% {
    filter: blur(5px);
  }
}

#moon-glow {
  position: fixed;
  pointer-events: none;
  transform: translate(-50%, -50%);
  mix-blend-mode: screen;
  opacity: 0;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 45%,
             rgba(255,250,200,1) 0%,
             rgba(255,220,100,0.45) 30%,
             rgba(255,180,0,0.08) 60%,
             rgba(255,180,0,0) 100%);
  filter: blur(18px);
  /*transition: opacity 0.6s ease, filter 0.6s ease;*/
  z-index: 5;
  animation: heroFadeIn 4s ease-out forwards;
  animation-delay: 1s;
}

.w-hero, .a-hero, .g-hero, .e-hero {
  position:absolute;
  line-height: 0.2em;
  opacity: 0;
  top: 15%;
  font-size: 10vw;
  -webkit-text-stroke: 1px var(--accent-yellow);
  text-shadow:
    0 0 5px rgba(200, 255, 255, 0.6),
    0 0 10px rgba(200, 255, 255, 0.4),
    0 0 15px rgba(200, 255, 255, 0.2);
	animation: wageFadeIn 3s ease-out forwards;
}

.w-hero {
  right: 55%;
  animation-delay: 2s;
}

.a-hero {
  right: 50%;
  animation-delay: 2.2s;
}

.g-hero {
  right: 45%;
  animation-delay: 2.4s;
}

.e-hero {
  right:40%;
  animation-delay: 2.6s;
}

@keyframes wageFadeIn {
  0% {
    opacity: 0;
    transform: scale(0.2);
  }
  50% {
    transform: scale(1);
    opacity: 0.5;
  }
  100% {
    transform: scale(0.8);
    opacity: 0.7;
  }
}

.unbekanntes-hero {
  position:absolute;
  left: 0%;
  top: 14%;
  opacity: 0;
  font-size: 15vw;
  -webkit-text-stroke: 1px var(--accent-yellow);
  text-shadow:
    0 0 5px rgba(200, 255, 255, 0.6),
    0 0 10px rgba(200, 255, 255, 0.4),
    0 0 15px rgba(200, 255, 255, 0.2);
	animation: unbekanntesFadeIn 3s ease-in-out forwards;
  animation-delay: 4s;
}

@keyframes unbekanntesFadeIn {
  0% {
    opacity: 0;
    transform: scale(0.7);
  }
  60% {
    transform: scale(1);
    opacity: 0.6;
  }
 100% {
    transform: scale(0.7);
    opacity: 0.8;
  }
}

.tagline {
  position:absolute;
  top: 29%;
  left:30%;
  font-size: 3vw;
  opacity: 0;
  -webkit-text-stroke: 1px var(--accent-yellow);
  text-shadow:
    0 0 5px rgba(200, 255, 255, 0.6),
    0 0 10px rgba(200, 255, 255, 0.4),
    0 0 15px rgba(200, 255, 255, 0.2);
  animation: taglineFadeIn 1s ease-out forwards;
  animation-delay:7s;
}

@keyframes taglineFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 0.5;
  }
}

#glow-light {
  position: absolute;
  width: 15vw;
  height: 15vw;
  border-radius: 50%;
  background-color: white;
  pointer-events: none; 
  z-index: 10; 
  filter: blur(30px); 
  opacity: 0.3;
  top: 0px; 
}

#ungesehen, #ungesehen-cta {
  align-items: start;
  padding: 50px;
}

#ungesehen-cta {
  text-align: center;
  opacity: 0.6;
}

#ungesehen-cta h2 {
  font-size: 2.5vw !important;
	// animation: bullets 3s ease-out forwards;
}

.img-spider-web img {
  // position: absolute;
  // right: 0px;
  margin-top: 0px;
  top: 0px;
}

.ungesehen-text {
  width: 50%;
  padding: 30px;
  background-color: rgba(255,255,255,0.1);
  // border: 3px solid rgba(var(--accent-yellow),0.3);
  border-radius: 25px;
}

@keyframes bullets {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 0.6;
  }
}

.ungesehen-text h2 {
  font-size: 2.5vw !important;
  //opacity: 0.6 !important;
	animation: bullets 3s ease-out forwards;
}