:root {
  --vlip--speed--quick: 0.15s;
  --vlip--speed--fast: 0.3s;
  --vlip--speed--normal: 0.45s;
  --vlip--speed--slow: 0.6s;
  --vlip--easing--easeOutBack: cubic-bezier(0.34, 1.56, 0.64, 1);
}

* {
  box-sizing: border-box;
}

.wp-block-code {
  overflow-x: scroll;
}
.wp-block-code code {
  width: -moz-max-content;
  width: max-content;
}

.wp-block-cover__inner-container {
  max-width: var(--wp--style--global--wide-size);
}
.wp-block-cover__inner-container > *:last-child {
  margin-bottom: 0;
}

:root {
  --header-menu-icon-height: 3rem;
  --header-menu-icon-width: var(--header-menu-icon-height);
  --header-template-padding: var(--wp--preset--spacing--1-rem);
}

@keyframes overlay-menu__fade-in-animation {
  from {
    opacity: 0;
    transform: translateX(1em);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
header.wp-block-template-part .wp-block-navigation__responsive-container {
  /* 
  	Convert SVG-Code to Data URI here
  	https://www.svgbackgrounds.com/tools/svg-to-css/ 
  */
}
header.wp-block-template-part .wp-block-navigation__responsive-container-container.is-menu-open {
  z-index: 99;
}
header.wp-block-template-part .wp-block-navigation__responsive-container-open, header.wp-block-template-part .wp-block-navigation__responsive-container-close {
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--header-menu-icon-height);
  width: var(--header-menu-icon-width);
}
header.wp-block-template-part .wp-block-navigation__responsive-container-open svg, header.wp-block-template-part .wp-block-navigation__responsive-container-close svg {
  display: none;
}
header.wp-block-template-part .wp-block-navigation__responsive-container-open::before {
  content: url("data:image/svg+xml,%3Csvg width='48' height='48' viewBox='0 0 48 48' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 32H34' stroke='black' stroke-width='2'/%3E%3Cpath d='M14 24H34' stroke='black' stroke-width='2'/%3E%3Cpath d='M14 16H34' stroke='black' stroke-width='2'/%3E%3C/svg%3E");
}
@media (min-width: 600px) {
  header.wp-block-template-part .wp-block-navigation__responsive-container-open:not(.always-shown) {
    display: none;
  }
}
header.wp-block-template-part .wp-block-navigation__responsive-container-close {
  top: calc(var(--wp--style--root--padding-right) / 2);
  right: calc(-1 * var(--wp--style--root--padding-right) / 2);
}
header.wp-block-template-part .wp-block-navigation__responsive-container-close::before {
  content: url("data:image/svg+xml,%3Csvg width='48' height='48' viewBox='0 0 48 48' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 34L34 14' stroke='black' stroke-width='2'/%3E%3Cpath d='M14 14L34 34' stroke='black' stroke-width='2'/%3E%3C/svg%3E");
}
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open {
  overflow: visible;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  box-shadow: 0px 25px 50px -12px rgba(0, 0, 0, 0.5);
}
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
  padding-top: 0 !important;
}
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item {
  font-size: var(--wp--preset--font-size--large);
  width: 100%;
}
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
  width: 100%;
  border-bottom: 1px solid var(--wp--preset--color--contrast);
}
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .submenu-container .wp-block-navigation-item,
header.wp-block-template-part .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item {
  font-size: var(--wp--preset--font-size--medium);
}

.wp-block-navigation .has-child:not(.open-on-click):hover > .wp-block-navigation__submenu-container {
  display: block;
}

.has-modal-open .is-menu-open .wp-block-navigation__responsive-container-content {
  display: flex;
  justify-content: center;
  height: 100vh;
  height: calc(100vh - 1 * var(--wp--style--root--padding-right));
}
.has-modal-open .is-menu-open .wp-block-navigation__responsive-container-content > .wp-block-navigation__container {
  flex-grow: unset;
  width: 100%;
}
.has-modal-open .is-menu-open .wp-block-navigation__responsive-container-open {
  visibility: hidden;
}
.has-modal-open .is-menu-open .wp-block-navigation__responsive-dialog {
  width: 100%;
  margin-top: 0 !important;
}
.has-modal-open .admin-bar .is-menu-open .wp-block-navigation__responsive-container-content {
  position: relative;
  z-index: 1;
}

.wpcf7-form {
  display: grid;
  gap: 1.25rem;
  max-width: 100%;
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
.wpcf7-form .wpcf7-select,
.wpcf7-form .wpcf7-text,
.wpcf7-form .wpcf7-textarea,
.wpcf7-form .wpcf7-select {
  display: block;
  width: 100%;
  background-color: white;
  border: 1px solid var(--wp--preset--color--contrast-300);
  border-radius: 4px;
}
.wpcf7-form .wpcf7-select {
  position: relative;
  background-image: url("data:image/svg+xml,%3Csvg width='48' height='48' viewBox='0 0 48 48' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 19L24 29L34 19' stroke='black' stroke-width='2'/%3E%3C/svg%3E");
  background-position: 100% 50%;
  background-repeat: no-repeat;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}
.wpcf7-form .wpcf7-list-item {
  position: relative;
  margin-left: 0;
  padding-left: 0;
}
.wpcf7-form .wpcf7-list-item > label {
  display: flex;
  gap: 0.5rem;
}
.wpcf7-form .wpcf7-list-item > label input {
  margin: 0;
}
.wpcf7-form .wpcf7-list-item > label > *:hover {
  cursor: pointer;
}
.wpcf7-form .wpcf7-checkbox,
.wpcf7-form .wpcf7-radio,
.wpcf7-form .wpcf7-acceptance {
  --box-size: 1.25rem;
  --box-marker-size: 0.75rem;
  --box-border-radius: 3px;
  margin-top: 0.75rem;
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label {
  position: relative;
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label input,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label input,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label input {
  opacity: 0;
  position: absolute;
  z-index: -1;
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::before {
  border-color: var(--wp--preset--color--primary);
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label input:checked ~ .wpcf7-list-item-label::after {
  background: var(--wp--preset--color--primary);
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label .wpcf7-list-item-label,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label .wpcf7-list-item-label {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  padding-left: 2rem;
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label .wpcf7-list-item-label::before, .wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label .wpcf7-list-item-label::after {
  display: block;
  position: absolute;
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label::before,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label .wpcf7-list-item-label::before {
  top: 0;
  left: 0;
  width: var(--box-size);
  height: var(--box-size);
  border: 1px solid var(--wp--preset--color--contrast-300);
  border-radius: var(--box-border-radius);
}
.wpcf7-form .wpcf7-checkbox .wpcf7-list-item > label .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-radio .wpcf7-list-item > label .wpcf7-list-item-label::after,
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label .wpcf7-list-item-label::after {
  top: calc((var(--box-size) - var(--box-marker-size)) / 2 + 1px);
  left: calc((var(--box-size) - var(--box-marker-size)) / 2 + 1px);
  width: var(--box-marker-size);
  height: var(--box-marker-size);
  background-color: transparent;
  border-radius: 5000rem;
}
.wpcf7-form .wpcf7-radio {
  display: flex;
  gap: 1.25rem;
}
.wpcf7-form .wpcf7-radio .wpcf7-list-item-label {
  font-size: var(--wp--preset--font-size--small);
}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item > label {
  align-items: flex-start;
}
.wpcf7-form .wpcf7-acceptance input {
  margin-top: calc(var(--wp--preset--spacing--30) / 5) !important;
}
.wpcf7-form .wpcf7-acceptance .wpcf7-list-item-label {
  font-size: var(--wp--preset--font-size--small);
  line-height: 1.5;
}

.wpcf7-form-control-wrap,
.wpcf7-form > .wpcf7-form-control,
.wpcf7-form-control-wrap > *,
.wpcf7-list-item-label,
.wpcf7-spinner,
.wpcf7-response-output {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}

.wpcf7-form-control:not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-acceptance),
.wpcf7-form-wrap {
  font-size: var(--wp--preset--font-size--regular);
  width: 100%;
  padding: 1rem 1.25rem;
}
.wpcf7-form-control:not(.wpcf7-checkbox):not(.wpcf7-radio):not(.wpcf7-acceptance).wpcf7-not-valid,
.wpcf7-form-wrap.wpcf7-not-valid {
  border-color: var(--wp--preset--color--vivid-red);
}

.wpcf7-form-wrap {
  background-color: white;
  border: 0 none transparent;
  border-radius: 4px;
  border: 1px solid var(--wp--preset--color--contrast-300);
}

.wpcf7-submit-wrap {
  position: relative;
  display: grid;
  gap: 1.25rem;
}

.wpcf7-submit {
  font-family: var(--wp--preset--font-family--inter);
  font-weight: 700;
  font-style: normal;
  font-size: 1.5rem;
  background-color: var(--wp--preset--color--primary);
  border: 1px solid var(--wp--preset--color--primary);
  border-radius: 4px;
  color: var(--wp--preset--color--base);
  transition: all var(--vlip--speed--quick) var(--vlip--easing--easeOutBack);
}
.wpcf7-submit:hover {
  opacity: 0.8;
  cursor: pointer;
}

.wpcf7-not-valid-tip {
  position: absolute;
  left: 1.25rem;
  bottom: 0;
  font-size: 0.75rem;
  color: var(--wp--preset--color--vivid-red);
}

.wpcf7-spinner {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.wpcf7-response-output {
  margin: 0 !important;
  padding: 1.125rem !important;
  border-radius: 4px;
}

.wpcf7 form.sent .wpcf7-response-output {
  background-color: var(--wp--preset--color--vivid-green-cyan);
  border-color: var(--wp--preset--color--vivid-green-cyan);
  color: white;
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  background-color: #ffb900;
}

input:focus-visible {
  border: 1px solid var(--wp--preset--color--primary) !important;
}

.wp-block-post-title {
  word-break: normal;
}

@media (max-width: 399px) {
  .page-template-wp-custom-template-anmeldung .wp-block-cover {
    padding: 0;
  }
}
.page-template-wp-custom-template-anmeldung .wp-block-cover .wp-block-cover__background {
  background-color: transparent;
  -webkit-backdrop-filter: blur(24px);
          backdrop-filter: blur(24px);
}
.page-template-wp-custom-template-anmeldung .wp-block-cover .wp-block-cover__inner-container {
  display: flex;
  justify-content: center;
}
.page-template-wp-custom-template-anmeldung .wp-block-cover .wp-block-post-featured-image {
  width: 100%;
  max-width: 400px;
  margin: 0;
}
