/* reset/native html */
*, *:before, *:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  font-family: 'Roobert Regular', sans-serif;
}

img {
  overflow-clip-margin: content-box;
  overflow: clip;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-weight: 500;
}

h1 {
  font-family: 'Youth Medium', sans-serif;
  font-size: 4.25rem;
  line-height: 3.825rem;
  letter-spacing: -0.1rem;
}
@media (max-width: 768px) {
  h1 {
    font-size: 2.625rem;
    line-height: 2.363rem;
    letter-spacing: -0.063rem;
  }
}

h2 {
  font-family: 'Youth Medium', sans-serif;
  font-size: 2.625rem;
  line-height: 2.363rem;
  letter-spacing: -0.063rem;
}
@media (max-width: 768px) {
  h2 {
    font-size: 2.125rem;
    line-height: 1.913rem;
    letter-spacing: -0.063rem;
  }
}

h3 {
  font-family: 'Youth Medium', sans-serif;
  font-size: 2.125rem;
  line-height: 1.913rem;
  letter-spacing: -0.063rem;
}
@media (max-width: 768px) {
  h3 {
    font-size: 1.5rem;
    line-height: 1.625rem;
    letter-spacing: -0.05rem;
  }
}

h4 {
  font-family: 'Roobert Medium', sans-serif;
  font-size: 1.5rem;
  line-height: 1.625rem;
  letter-spacing: -0.05rem;
}
@media (max-width: 768px) {
  h4 {
    font-size: 1.125rem;
    line-height: 1.238rem;
    letter-spacing: -0.038rem;
  }
}

h5 {
  font-family: 'Roobert Medium', sans-serif;
  font-size: 1.125rem;
  line-height: 1.5rem;
  letter-spacing: -0.038rem;
}

h6 { /* Special Headline; doesn't follow the typical headline logic! */
  font-family: 'Youth Medium', sans-serif;
  font-size: 3.375rem;
  line-height: 3.038rem;
  letter-spacing: -0.094rem;
}
@media (max-width: 768px) {
  h6 {
    font-size: 2.625rem;
    line-height: 2.363rem;
    letter-spacing: -0.063rem;
  }
}

a {
  font-size: 1rem;
  font-family: "Roobert Medium", sans-serif;
  color: var(--dark-primary);
  text-decoration-color: var(--a-underline);
  gap: .5rem;
  text-underline-offset: .2rem;
  cursor: pointer;
}

p {
  margin: 0;
  font-weight: 400;
  font-family: 'Roobert Regular', sans-serif;
  font-size: 1rem;
  line-height: 1.5rem;
  letter-spacing: 0;
}

button {
  padding: 0 3rem;
  width: fit-content;
  color: var(--white);
  background-color: var(--dark-primary);
  border-radius: 0.875rem;
  font-family: 'Roobert Medium', sans-serif;
  height: 2.563rem;
  font-size: 18px;
  line-height: 1.238rem;
  letter-spacing: -0.038rem;
  cursor: pointer;
  border: none;
}

textarea,
select,
input {
  padding: .875rem 1.25rem;
  border-radius: .875rem;
  border-color: var(--dark-disabled);
  border-width: 1px;
  font-family: "Roobert Regular", sans-serif;
  background-color: white;
}
input::placeholder {
  color: var(--dark-terteriary)
}

.custom-select-wrapper {
  position: relative;
  display: inline-block;
  width: 200px;
}

.custom-select-wrapper select {
  appearance: none;
  -webkit-appearance: none; /* für Safari */
  -moz-appearance: none;    /* für Firefox */
  width: 100%;
  cursor: pointer;
}

.custom-select-wrapper::after {
  content: url("../icons/select-icon.svg");
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transform-origin: center; /* Wichtig für saubere Drehung */
  transition: transform 0.3s ease;
  pointer-events: none;
  display: inline-block;
  line-height: 0; /* verhindert minimale Verschiebung */
}
.custom-select-wrapper.open::after {
  transform: translateY(-50%) rotate(180deg);
}


input[type="checkbox"] {
  cursor: pointer;
}