* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  font-family: Arial, Helvetica, sans-serif;
}

body {
  width: 100vw;
  min-height: 100svh;
  overflow-x: hidden;
  overflow: hidden; /* prevent horizontal scrolling initially */
}

.container {
  min-height: 100svh;
  position: relative;
  background: linear-gradient(
    223.17deg,
    rgb(40, 151, 255) 0%,
    rgb(58, 151, 230) 8.61%,
    rgb(76, 151, 215) 17.21%,
    rgb(90, 151, 200) 25.82%,
    rgb(108, 151, 185) 34.42%,
    rgb(130, 151, 160) 43.03%,
    rgb(151, 151, 151) 51.63%
  );
}

.errorcontainer {
  min-height: 100svh;
  position: relative;
  background: linear-gradient(
    223.17deg,
    rgb(40, 151, 255) 0%,
    rgb(58, 151, 230) 8.61%,
    rgb(76, 151, 215) 17.21%,
    rgb(90, 151, 200) 25.82%,
    rgb(108, 151, 185) 34.42%,
    rgb(130, 151, 160) 43.03%,
    rgb(151, 151, 151) 51.63%
  );
}

.errortext {
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -50px;
  margin-left: -50px;
  width: 100px;
  height: 100px;
  color: white;
}

.centered {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 3rem;
  text-align: center;
  color: white;
}

.overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: black;
  z-index: 1;
  pointer-events: none;
}

.vitalia-main-container {
  width: 100%;
  height: 100vh;
  position: relative;
  transform: scale(1.25);
  /*background-image: url("../img/Hintergrund.png");
  background-size: 1000vh;
  background-position: 50% 41.7%;
  background-repeat: no-repeat;
  background-origin: content-box; */
  padding-bottom: 200px;
}

.vitalia-main-image {
  width: 100%;
  height: 100vh;
  /* transform: scale(1.25); */
  position: absolute;
  inset: 0;
  object-fit: cover;
}

.vitalia-main-logo {
  width: 100%;
  height: 100vh;
  position: absolute;
  inset: 0;
  z-index: 1;
  object-fit: cover;
  opacity: 0.3;
}

.vitalia-text-logo-container {
  width: 100%;
  height: 100vh;
  position: absolute;
  inset: 0;
  z-index: -1;
  object-fit: cover;
  background-color: transparent;
  display: flex;
  flex-direction: column;
  gap: 4rem;
  justify-content: center;
  align-items: center;
}

.vitalia-text-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background-repeat: no-repeat;
  background-position: 50% 41.7%;
  background-size: 28vh;
  background-repeat: no-repeat;
  background-origin: content-box;
  padding-bottom: 200px;
  height: 100vh;
  position: absolute;
  inset: 0;
}

.vitalia-text {
  color: #ffb0c4;
  text-align: center;
  text-transform: uppercase;
  background-image: radial-gradient(
    circle at 50% 200vh,
    rgba(255, 214, 135, 0) 0,
    rgba(224, 228, 2, 0.5) 90vh,
    rgba(125, 128, 0, 0.8) 120vh,
    rgba(32, 31, 66, 0) 150vh
  );
  -webkit-text-fill-color: transparent;
  font-size: 4.5rem;
  background-clip: text;
  width: 100%;
  line-height: 0.9;
  margin-top: 55%;
}

.vitalia-0-container {
  position: fixed;
  width:500px;
}

.vitalia-0-container-buttons {
  display: inline-block;
  position: fixed;
  right: 0;
  padding-right: 1.0em;
}

.social {
  display: inline-block;
  position: fixed;
  right: 0;
  bottom: 0;
  padding-right: 1.0em;
  width: 4%;
}

.social-img{
  width: 100%;
}

.toplogo{
  display: inline-block;
  position: fixed;
  left: 0;
  width: 7%;
}

.toplogo-img{
  width: 100%;
}

.topbutton {
  align-items: center;
  appearance: none;
  background-image: radial-gradient(100% 100% at 100% 0, #5adaff 0, #5468ff 100%);
  border: 0;
  border-radius: 6px;
  box-shadow: rgba(45, 35, 66, .4) 0 2px 4px,rgba(45, 35, 66, .3) 0 7px 13px -3px,rgba(58, 65, 111, .5) 0 -3px 0 inset;
  box-sizing: border-box;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font-family: "JetBrains Mono",monospace;
  height: 48px;
  justify-content: center;
  line-height: 1;
  list-style: none;
  overflow: hidden;
  padding-left: 16px;
  padding-right: 16px;
  position: relative;
  text-align: left;
  text-decoration: none;
  transition: box-shadow .15s,transform .15s;
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
  white-space: nowrap;
  will-change: box-shadow,transform;
  font-size: 18px;
}

.topbutton:focus {
  box-shadow: #3c4fe0 0 0 0 1.5px inset, rgba(45, 35, 66, .4) 0 2px 4px, rgba(45, 35, 66, .3) 0 7px 13px -3px, #3c4fe0 0 -3px 0 inset;
}

.topbutton:hover {
  box-shadow: rgba(45, 35, 66, .4) 0 4px 8px, rgba(45, 35, 66, .3) 0 7px 13px -3px, #3c4fe0 0 -3px 0 inset;
  transform: translateY(-2px);
}

.topbutton:active {
  box-shadow: #3c4fe0 0 3px 7px inset;
  transform: translateY(2px);
}

.topbutton2 {
  align-items: center;
  appearance: none;
  background-image: radial-gradient(100% 100% at 100% 0, #e6ff5a 0, #adb900 100%);
  border: 0;
  border-radius: 6px;
  box-shadow: rgba(45, 35, 66, .4) 0 2px 4px,rgba(45, 35, 66, .3) 0 7px 13px -3px,rgba(58, 65, 111, .5) 0 -3px 0 inset;
  box-sizing: border-box;
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  font-family: "JetBrains Mono",monospace;
  height: 60px;
  justify-content: center;
  line-height: 1;
  list-style: none;
  overflow: hidden;
  padding-left: 32px;
  padding-right: 32px;
  position: relative;
  text-align: left;
  text-decoration: none;
  transition: box-shadow .15s,transform .15s;
  user-select: none;
  -webkit-user-select: none;
  touch-action: manipulation;
  white-space: nowrap;
  will-change: box-shadow,transform;
  font-size: 22px;
}

.topbutton2:focus {
  box-shadow: #e6ff5a 0 0 0 1.5px inset, rgba(45, 35, 66, .4) 0 2px 4px, rgba(45, 35, 66, .3) 0 7px 13px -3px, #adb900 0 -3px 0 inset;
}

.topbutton2:hover {
  box-shadow: rgba(213, 255, 28, 0.4) 0 4px 8px, rgba(45, 35, 66, .3) 0 7px 13px -3px, #adb900 0 -3px 0 inset;
  transform: translateY(-2px);
}

.topbutton2:active {
  box-shadow: #d0e03c 0 3px 7px inset;
  transform: translateY(2px);
}

.top-background{
  display: inline-block;
  position: fixed;
  left: 0;
}

.top-background-img{
  width: 100%;
  opacity: 0.3;
}

.vitalia-1-container {
  visibility: hidden;
}

.vitalia-2-container {
  width: 100%;
  height: 100vh;
  position: absolute;
  inset: 0;
  opacity: 0;
  object-fit: cover;
  background-image: radial-gradient(
    circle at 50% 200vh,
    rgba(255, 214, 135, 0) 0,
    rgba(224, 228, 2, 0.5) 90vh,
    rgba(125, 128, 0, 0.8) 120vh,
    rgba(32, 31, 66, 0) 150vh
  );
  -webkit-text-fill-color: transparent;
  font-size: 6rem;
  background-clip: text;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 0 2rem;
  visibility: hidden;
}

.logo{
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 30%;
}

.vitalia-2-container p {
  max-width: 90%;
  font-size: 1rem;
}

.vitalia-2-container h3 {
  font-size: 2.5rem;
}

@media (min-width: 1024px) {
  .vitalia-text {
    font-size: 6rem;
  }

  .scroll-indicator {
    bottom: 30px;
  }

  .vitalia-2-container {
    margin: 0 auto;
    max-width: 60%;
    padding: 0;
  }

  .vitalia-2-container p {
    max-width: 90%;
    font-size: 2rem;
  }

  .vitalia-2-container h3 {
    font-size: 3.5rem;
  }
}
