@charset "UTF-8";
:root, *::before, *::after {
  --ff-sans: mietspiegel, "Merriweather Sans", ui-sans-serif, sans-serif;
  --ff-sans-ch:"Merriweather Sans", ui-sans-serif, sans-serif;
  --ff-sans-alt: mietspiegel, "Raleway", ui-sans-serif, sans-serif;
  --ff-sans-headline: mietspiegel, "Oswald", ui-sans-serif, sans-serif;
  --ff-serif: mietspiegel,"Merriweather", ui-serif, serif;
  --ff-serif-alt: "Lora", ui-serif, serif;
  --ff-hand: "Comic Neue", cursive;
  --ff-deco: "Great Vibes", fantasy;
  --ff-icons: mietspiegel;
}

:root, *::before, *::after {
  --max-body-width: 1000px;
  --main-content-side-padding: 1rem;
  --max-line-length: 70ch;
  --max-textbox-width: calc(var(--max-line-length) + 2 * var(--main-content-side-padding));
  --header-height: clamp(90px, 10vh, 150px);
  --navigation-height: 80px;
  --footer-menu-height: 3em;
  --std-distance: .5rem;
  --std-spacing: 2rem;
  --window-padding: 1rem;
  --logo-safety-frame: 5px;
}

html {
  height: 100%;
  scroll-padding-top: var(--header-height);
  background-color: var(--structuring-color);
  background-color: var(--outside-bgr-color);
}

body {
  background-color: var(--std-bgr-color);
  color: var(--std-text-color);
  margin-top: var(--header-height);
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  font-family: var(--copy-ff);
  max-width: var(--max-body-width);
  line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--headline-ff);
}

h1,
h2 {
  color: var(--std-headline-color);
}

input {
  font-size: 1rem;
}

section.questionnaire-container {
  opacity: 0;
}

body.ready section.questionnaire-container {
  opacity: 1;
  transition: opacity 0.5s;
}

body > header {
  position: fixed;
  top: 0;
  width: 100%;
  max-width: var(--max-body-width);
  height: var(--header-height);
  overflow: hidden;
  display: grid;
  grid-template-columns: 33% auto;
  grid-template-rows: 100%;
  gap: var(--std-distance);
  background-color: var(--header-bgr-c);
  z-index: 100;
}
body > header .logo {
  padding: var(--logo-safety-frame);
}
body > header .logo img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}
body > header .logo.left img {
  object-position: left;
}
body > header .main-headline-container {
  align-self: center;
  justify-self: right;
}
@media screen and (max-width: 1000px) {
  body > header .main-headline-container {
    padding-right: var(--std-distance);
  }
}

body.subpages header h2,
h1 {
  font-weight: 100;
  text-align: right;
  font-size: 2.5em;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-left: 1.5em;
  width: fit-content;
  border-bottom-style: solid;
  border-bottom-color: currentcolor;
  border-bottom-width: 0.01em;
  color: var(--std-headline-color);
}
body.subpages header h2 .year,
h1 .year {
  font-weight: 300;
  color: hsl(var(--ci-color-HS-frag) 30%);
}

body.subpages h1 {
  font-weight: 300;
  text-transform: none;
  border: none;
  text-align: left;
  letter-spacing: normal;
  padding-left: 0;
}
body.subpages article > h2 {
  margin-top: 1em;
  font-size: 1.75em;
  font-weight: 400;
  letter-spacing: normal;
}
body.subpages h2 + h3 {
  margin-top: 0em;
}
body.subpages h3 {
  font-size: 1.5em;
  font-weight: 400;
  letter-spacing: normal;
}
body.subpages h4 {
  font-size: 1.25em;
  font-weight: 400;
  letter-spacing: normal;
  margin-bottom: 0.5em;
}
body.subpages h4 + p {
  margin-top: 0;
}

main {
  height: calc(100vh - var(--header-height) - var(--footer-menu-height) - 2px);
  position: relative;
  overflow: hidden;
  border-color: hsla(var(--structuring-color-HS-frag) 75%/0.8);
  border-width: 1px;
  border-style: solid;
}
@supports (height: 100dvh) {
  main {
    height: calc(100dvh - var(--header-height) - var(--footer-menu-height) - 2px);
  }
}
main.basic-info-emphasized {
  --bf-info-height: 60px;
  --bf-info-headline-text-c: var(--inverted-text-color);
  --bf-info-headline-bgr-c: hsl(var(--day-color-HS-frag) 35%);
  --bf-info-headline-text-weight: 300;
  --bf-info-headline-letter-spacing: .05em;
}
main > div#window {
  z-index: 50;
  position: absolute;
  top: calc(var(--bf-info-height) - 2px);
  left: 0;
  right: -1px;
  bottom: var(--nav-height);
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-gutter: stable;
  padding: var(--window-padding);
  background: linear-gradient(var(--std-bgr-color) 30%, hsla(var(--std-bgr-color-HSL-frag)/0)), linear-gradient(hsla(var(--std-bgr-color-HSL-frag)/0), var(--std-bgr-color) 70%) 0 100%, radial-gradient(farthest-side at 50% 0, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0)), radial-gradient(farthest-side at 50% 100%, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0)) 0 100%;
  background-repeat: no-repeat;
  background-size: 100% 40px, 100% 40px, 100% 14px, 100% 14px;
  background-attachment: local, local, scroll, scroll;
}
@supports not (scrollbar-gutter: stable) {
  main > div#window {
    padding-right: calc(17px + var(--window-padding));
  }
}
main > div#window.disabled {
  box-shadow: inset 0 0 15px rgba(0, 0, 0, 0.4);
  pointer-events: none;
  overflow-y: hidden;
}
main > div#window.disabled form {
  filter: blur(10px);
}

section.basic-info-container,
section.basic-info-container *::before,
section.basic-info-container *::after {
  --baseunit: calc(1em * (50 / 16));
  --border-width: calc(1em * (3 / 16));
  --lable-font-size: 1.5em;
  --lable-line-height: calc(var(--lable-font-size) * 1.25);
  --cell-hor-padding: var(--baseunit);
  --cell-vert-padding: calc(var(--baseunit) / 2);
  --input-fs-increase: 1.5;
  --cell-height: calc(calc(var(--baseunit)) + calc(var(--border-width) * var(--input-fs-increase)) + 2 * var(--cell-vert-padding));
  --large-input-width: 400px;
  --close-speed: .3s;
}

section.basic-info-container {
  background-color: var(--bf-bgr-c);
  color: var(--bf-text-c);
  position: absolute;
  top: 0;
  transform: translateY(0);
  width: calc(100% + 0px);
  box-shadow: 3px 0 10px 2px rgba(0, 0, 0, 0.5);
  clip-path: inset(0% 0% -10% 0%);
  left: 0;
  z-index: 200;
  display: grid;
  grid-template-columns: 382fr 309fr 309fr;
  grid-template-rows: 2fr 4fr 4fr 2fr auto auto;
  grid-template-areas: "bflegend empty empty" "bflegend input1 input1" "bflegend input2 input3" "bflegend submit submit" "infohl infohl infohl" "info info info";
  will-change: clip-path, transform;
  transition: transform var(--close-speed) ease-in, clip-path var(--close-speed) ease-in;
}
section.basic-info-container.closed {
  transform: translateY(calc(-100% + var(--bf-info-height) - 2px));
  clip-path: inset(calc(100% - var(--bf-info-height) - 2px) 0% 0% 0%);
}
section.basic-info-container.closed #basic-info-display h4 {
  height: calc(var(--bf-info-height) - var(--bf-info-main-height));
  transition: height 0.3s ease-in 0.15s;
}
section.basic-info-container.closed #basic-info-display .info,
section.basic-info-container.closed #basic-info-display .edit-button-container {
  height: var(--bf-info-main-height);
  transition: height 0.3s ease-in 0.15s;
}
section.basic-info-container.closed #basic-info-display .info button,
section.basic-info-container.closed #basic-info-display .edit-button-container button {
  display: block;
}
section.basic-info-container.closed #basic-info fieldset .input-group-container .button.basic-info button {
  outline: none;
}
section.basic-info-container.closed #basic-info fieldset .input-group-container .button.basic-info button:focus, section.basic-info-container.closed #basic-info fieldset .input-group-container .button.basic-info button:active, section.basic-info-container.closed #basic-info fieldset .input-group-container .button.basic-info button:hover, section.basic-info-container.closed #basic-info fieldset .input-group-container .button.basic-info button:focus-visible {
  outline: none;
}
section.basic-info-container #basic-info {
  position: absolute;
  height: 100%;
  width: 100%;
  display: contents;
}
section.basic-info-container #basic-info fieldset {
  display: contents;
}
section.basic-info-container #basic-info fieldset legend {
  grid-area: bflegend;
  padding: 2em;
  background-image: var(--bf-bgr-image);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: top left;
  color: var(--bf-text-c);
  font-family: var(--bf-text-ff);
  font-size: 93%;
  line-height: 1.3;
  font-weight: 200;
  border-right-width: 1px;
  border-right-style: solid;
  border-image: linear-gradient(to bottom, transparent 0%, hsla(var(--structuring-color-HSL-frag)/0.5) 33%, hsla(var(--structuring-color-HSL-frag)/0.5), transparent 100%) 1;
}
section.basic-info-container #basic-info fieldset legend h3 {
  color: var(--bf-headline-c);
  font-size: 2em;
  font-family: var(--bf-headline-ff);
  font-weight: 200;
  margin-top: 0;
  margin-bottom: 0.5em;
}
section.basic-info-container #basic-info fieldset legend h3::before {
  content: "— ";
}
section.basic-info-container #basic-info fieldset .input-group-container {
  display: contents;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group {
  padding-top: var(--cell-vert-padding);
  padding-bottom: var(--cell-vert-padding);
  padding-left: var(--cell-hor-padding);
  padding-right: var(--cell-hor-padding);
  height: var(--cell-height);
  justify-self: center;
  width: calc(100% - 2 * var(--cell-hor-padding));
  max-width: var(--large-input-width);
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group:focus-within label {
  color: var(--inverted-text-color);
  font-weight: 300;
  letter-spacing: unset;
  transition: color 0.3s linear;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group label {
  display: block;
  height: var(--lable-line-height);
  line-height: var(--lable-line-height);
  font-size: var(--lable-font-size);
  font-family: var(--bf-label-ff);
  color: var(--bf-label-text-color);
  font-weight: var(--bf-label-fw);
  letter-spacing: 0.015em;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder {
  position: relative;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder .icon::before {
  --icon-fs-increase: 2.5;
  --myunit: calc(var(--baseunit) / var(--icon-fs-increase));
  font-size: calc(1em * var(--icon-fs-increase));
  content: "🛈";
  position: absolute;
  display: block;
  width: calc(var(--myunit));
  height: calc(var(--myunit));
  top: 0;
  left: 0;
  background-color: var(--bf-input-icon-bgr-c);
  font-family: var(--ff-icons);
  color: var(--bf-input-icon-c);
  line-height: var(--myunit);
  text-align: center;
  transition: color 0.3s ease-in 0s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder .icon::after {
  --warn-icon-fs-increase: 1.6;
  --myunit: calc(var(--baseunit) / var(--warn-icon-fs-increase));
  font-size: calc(1em * var(--warn-icon-fs-increase));
  color: var(--bf-input-warn-sign-c);
  content: "⚠";
  font-family: var(--ff-icons);
  position: absolute;
  line-height: var(--myunit);
  right: 0.4ch;
  top: calc(var(--myunit) / 34);
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s linear 2s, visibility 0s linear 0s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder:focus-within .icon::before {
  background-color: var(--bf-input-icon-bgr-focus-c);
  color: var(--bf-input-icon-focus-c);
  transition: all linear 0.3s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text],
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number] {
  --myunit: calc(var(--baseunit) / var(--input-fs-increase));
  outline: none;
  border-style: none;
  color: var(--bf-input-text-c);
  font-family: var(--bf-input-text-ff);
  font-size: calc(1em * var(--input-fs-increase));
  line-height: var(--myunit);
  padding-top: 0;
  padding-bottom: 0;
  padding-left: calc(1.25ch + var(--myunit));
  padding-right: 0;
  border-bottom-style: solid;
  border-bottom-width: var(--border-width);
  border-bottom-color: var(--bf-input-border-c);
  height: var(--myunit);
  background-color: var(--bf-input-bgr-c);
  width: calc(100% - 1.25ch - var(--myunit));
  transition: background-color linear 0.3s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]::placeholder,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]::placeholder {
  color: var(--bf-input-placeholder-c);
  font-weight: 100;
  font-size: 80%;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:placeholder-shown,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:placeholder-shown {
  border-bottom-color: var(--bf-input-border-empty-c);
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:focus,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:focus {
  background-color: var(--bf-input-bgr-focus-c);
  color: var(--bf-input-text-focus-c);
  border-bottom-color: var(--bf-input-border-focus-c);
  transition: all linear 0.3s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:focus::placeholder,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:focus::placeholder {
  color: var(--bf-input-placeholder-focus-c);
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:invalid:not(:placeholder-shown),
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:invalid:not(:placeholder-shown) {
  background-color: var(--bf-input-bgr-focus-c);
  color: var(--bf-input-text-focus-c);
  border-bottom-color: var(--bf-input-border-error-c);
  transition: border-bottom-color 0.3s linear 2s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:invalid:not(:placeholder-shown) ~ .validation-error-msg,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:invalid:not(:placeholder-shown) ~ .validation-error-msg {
  visibility: visible;
  opacity: 1;
  transition: opacity 0.3s linear 2s, visibility 0s linear 0s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:invalid:not(:placeholder-shown) ~ .icon::before,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:invalid:not(:placeholder-shown) ~ .icon::before {
  background-color: var(--bf-input-icon-bgr-error-c);
  color: var(--bf-input-icon-error-c);
  transition: all 0.3s linear 2s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:invalid:not(:placeholder-shown) ~ .icon::after,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:invalid:not(:placeholder-shown) ~ .icon::after {
  visibility: visible;
  opacity: 1;
  transition: opacity 0.3s linear 2s, visibility 0s linear 0s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=text]:not(:focus) ~ .validation-error-msg,
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder input[type=number]:not(:focus) ~ .validation-error-msg {
  display: none !important;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group .input-holder .validation-error-msg {
  position: absolute;
  top: 100%;
  left: 0;
  width: calc(100% - 1em);
  background-color: var(--bf-input-icon-bgr-error-c);
  color: var(--bf-input-icon-error-c);
  font-size: 80%;
  padding: 0.5em;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s linear 0s, visibility 0s linear 0.3s;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.objectname .input-holder .icon::before {
  content: "🏘";
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.year, section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.area {
  max-width: calc((var(--large-input-width) - var(--cell-hor-padding)) / 2);
  width: calc(100% - var(--cell-hor-padding) * 1.5);
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.year {
  justify-self: left;
  padding-left: calc(var(--cell-hor-padding) / 2);
  padding-right: 0;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.year .input-holder .icon::before {
  content: "⛏";
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.area {
  justify-self: right;
  padding-right: calc(var(--cell-hor-padding) / 2);
  padding-left: 0;
}
section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.area .input-holder .icon::before {
  content: "⌗";
}
section.basic-info-container #basic-info fieldset .input-group-container .objectname {
  grid-area: input1;
}
section.basic-info-container #basic-info fieldset .input-group-container .area {
  grid-area: input2;
}
section.basic-info-container #basic-info fieldset .input-group-container .year {
  grid-area: input3;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info {
  grid-area: submit;
  height: auto;
  padding: 0;
  justify-self: right;
  align-self: bottom;
  position: relative;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button {
  appearance: none;
  position: absolute;
  right: 0;
  bottom: 0;
  border: none;
  width: calc(var(--baseunit) * 1.5);
  height: calc(var(--baseunit) * 1.5);
  background-color: var(--bf-button-bgr-c);
  padding: 0;
  cursor: pointer;
  outline-color: var(--bf-button-bgr-c);
  outline-color: transparent;
  outline-width: calc(var(--baseunit) * 0.75);
  outline-style: solid;
  outline-offset: calc(-1 * var(--baseunit) * 0.75);
  transition: background-color 0.3s linear;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button::before {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  font-family: var(--ff-icons);
  content: "🡲";
  color: var(--bf-button-text-c);
  font-size: var(--baseunit);
  line-height: 1.5;
  text-align: center;
  white-space: nowrap;
  transition: color 0.3s linear, transform 0.3s ease-out;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:hover, section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:focus {
  background-color: var(--bf-button-bgr-focus-c);
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:hover::before, section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:focus::before {
  color: var(--bf-button-text-focus-c);
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:focus {
  box-shadow: 0 0 4px 1px hsla(var(--ci-color-HSL-frag)/0.3);
  outline-color: hsla(var(--ci-color-HSL-frag), 0.7);
  outline-width: 2px;
  outline-style: solid;
  outline-offset: -2px;
  transition: outline-offset 0.75s cubic-bezier(0, 0.5, 0, 1), outline-width 0.75s cubic-bezier(0, 0.5, 0, 1), outline-color 0.75s cubic-bezier(0, 0.5, 0, 1);
  animation: button-focus 0.75s ease-in-out 0.5s 1 normal forwards, button-outline-focus 0.75s cubic-bezier(0, 0.5, 0, 1) 1.5s 1 normal forwards;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button:focus-visible {
  box-shadow: 0 0 4px 1px hsla(var(--ci-color-HSL-frag)/0.3);
  outline-color: var(--bf-button-bgr-c);
  outline-width: 5px;
  outline-style: solid;
  outline-offset: -2px;
  background-color: var(--nav-button-bgr-focus-c);
  transition: outline-offset 0.75s cubic-bezier(0, 0.5, 0, 1), outline-width 0.75s cubic-bezier(0, 0.5, 0, 1), outline-color 0.75s cubic-bezier(0, 0.5, 0, 1);
  animation: none;
}
section.basic-info-container #basic-info fieldset .input-group-container .button.basic-info button span {
  font-size: 0;
}
section.basic-info-container #basic-info:invalid fieldset .input-group-container .formelement-group.button.basic-info button {
  background-color: var(--bf-button-bgr-disabled-c);
  pointer-events: none;
  transition: background-color 0.3s linear;
}
section.basic-info-container #basic-info:invalid fieldset .input-group-container .formelement-group.button.basic-info button::before {
  color: var(--bf-button-text-disabled-c);
  transition: color 0.3s linear;
}
section.basic-info-container #basic-info-display {
  display: contents;
}
section.basic-info-container #basic-info-display h4 {
  --myHeight: calc(var(--bf-info-height) - var(--bf-info-main-height));
  grid-area: infohl;
  height: 0;
  overflow: hidden;
  font-size: calc(var(--myHeight) * 0.8);
  font-weight: var(--bf-info-headline-text-weight);
  letter-spacing: var(--bf-info-headline-letter-spacing);
  text-transform: uppercase;
  letter-spacing: 0.01em;
  line-height: var(--myHeight);
  background-color: var(--bf-info-headline-bgr-c);
  color: var(--bf-info-headline-text-c);
  margin: 0;
  padding-left: 1ch;
  transition: height 0.3s linear;
}
section.basic-info-container #basic-info-display h4::after {
  content: ":";
}
section.basic-info-container #basic-info-display .info {
  grid-area: info;
  display: flex;
  align-items: center;
  height: 0;
  overflow: hidden;
  background-color: var(--bf-info-bgr-c);
  color: var(--bf-info-text-c);
  padding-left: 1ch;
  transition: height 0.3s linear;
  width: calc(100% - var(--bf-info-main-height) - 1ch);
  min-width: calc(100% - var(--bf-info-main-height) - 1ch);
}
section.basic-info-container #basic-info-display .info div {
  flex-grow: 1;
}
section.basic-info-container #basic-info-display .info div span.label {
  font-weight: 200;
}
section.basic-info-container #basic-info-display .info div span.label::after {
  content: ": ";
}
section.basic-info-container #basic-info-display .edit-button-container {
  position: absolute;
  right: 0;
  bottom: 0;
  background-color: var(--bf-info-bgr-c);
  width: var(--bf-info-main-height);
  overflow: hidden;
}
section.basic-info-container #basic-info-display .edit-button-container button {
  display: none;
  appearance: none;
  position: absolute;
  bottom: 3px;
  border: none;
  width: var(--bf-info-main-height);
  height: var(--bf-info-main-height);
  background-color: transparent;
  padding: 0;
  cursor: pointer;
  outline: none;
  font-size: 0;
  transition: all 0.3s ease-out;
  box-sizing: content-box;
}
section.basic-info-container #basic-info-display .edit-button-container button::before {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  font-family: var(--ff-icons);
  content: "⌄";
  color: var(--bf-info-arrow-c);
  font-size: calc(var(--bf-info-main-height) * 0.7);
  line-height: var(--bf-info-main-height);
  text-align: center;
  white-space: nowrap;
  text-shadow: 0px 0px 1px rgba(0, 0, 0, 0);
  transition: all 0.3s ease-out;
}
section.basic-info-container #basic-info-display .edit-button-container button:hover, section.basic-info-container #basic-info-display .edit-button-container button:focus {
  bottom: 0;
  transition: all 0.3s ease-in;
}
section.basic-info-container #basic-info-display .edit-button-container button:hover::before, section.basic-info-container #basic-info-display .edit-button-container button:focus::before {
  color: var(--bf-info-arrow-hover-c);
  text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.4);
  transition: all 0.3s ease-in;
}

section.basic-info-container.reopened #basic-info fieldset .input-group-container .button.basic-info button::before {
  transform: rotate(-90deg);
  transition: rotate 0.3s ease-in;
}

body.ready section.navigation nav menu li {
  display: inline;
}

section.navigation {
  position: absolute;
  bottom: 0;
  background-color: var(--nav-bgr-c);
  height: var(--nav-height);
  overflow: hidden;
  width: 100%;
}
section.navigation nav menu {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: min-content auto min-content min-content min-content;
  grid-template-areas: "back . restart resetme next";
  gap: 2px;
}
section.navigation nav menu li {
  display: none;
  position: relative;
}
section.navigation nav menu li.back {
  grid-area: back;
}
section.navigation nav menu li.restart {
  grid-area: restart;
}
section.navigation nav menu li.reset {
  grid-area: resetme;
}
section.navigation nav menu li.next {
  grid-area: next;
}
section.navigation nav menu li button {
  appearance: none;
  position: relative;
  top: 0;
  left: 0;
  border: none;
  width: var(--nav-height);
  height: var(--nav-height);
  background-color: var(--nav-button-bgr-c);
  padding: 0;
  cursor: pointer;
  outline: none;
  font-size: 0;
  outline-color: hsla(var(--ci-color-HSL-frag)/0);
  outline-width: calc(var(--nav-height) / 2);
  outline-style: solid;
  outline-offset: calc(-1 * var(--nav-height) / 2);
  transition: background-color 0.3s ease-out, outline-offset 0.5s cubic-bezier(0, 0.5, 0, 1), outline-width 0.5s cubic-bezier(0, 0.5, 0, 1), outline-color 0.5s cubic-bezier(0, 0.5, 0, 1);
}
section.navigation nav menu li button::before {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  font-family: var(--ff-icons);
  content: "";
  color: var(--nav-button-text-c);
  font-size: calc(var(--nav-height) * 0.7);
  line-height: var(--nav-height);
  text-align: center;
  white-space: nowrap;
  text-shadow: 0px 0px 1px rgba(0, 0, 0, 0);
  transition: all 0.3s ease-out;
}
section.navigation nav menu li button:disabled {
  pointer-events: none;
  opacity: 0.25;
}
section.navigation nav menu li button:hover, section.navigation nav menu li button:focus, section.navigation nav menu li button:focus-visible {
  bottom: 0;
  transition: background-color 0.3s ease-in;
  background-color: var(--nav-button-bgr-focus-c);
}
section.navigation nav menu li button:hover::before, section.navigation nav menu li button:focus::before, section.navigation nav menu li button:focus-visible::before {
  color: var(--nav-button-text-focus-c);
  text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.4);
  transition: all 0.3s ease-in;
}
section.navigation nav menu li button:focus {
  box-shadow: 0 0 4px 1px hsla(var(--ci-color-HSL-frag)/0.3);
  outline-color: hsla(var(--ci-color-HSL-frag)/0.7);
  outline-width: 2px;
  outline-style: solid;
  outline-offset: -2px;
  transition: outline-offset 0.75s cubic-bezier(0, 0.5, 0, 1), outline-width 0.75s cubic-bezier(0, 0.5, 0, 1), outline-color 0.75s cubic-bezier(0, 0.5, 0, 1);
  animation: button-focus 0.75s ease-in-out 0.5s 1 normal forwards, button-outline-focus 0.75s cubic-bezier(0, 0.5, 0, 1) 1.5s 1 normal forwards;
}
section.navigation nav menu li button:focus-visible {
  box-shadow: 0 0 4px 1px hsla(var(--ci-color-HSL-frag)/0.3);
  outline-color: hsla(var(--ci-color-HSL-frag)/1);
  outline-width: 5px;
  outline-style: solid;
  outline-offset: -2px;
  background-color: var(--nav-button-bgr-focus-c);
  transition: outline-offset 0.75s cubic-bezier(0, 0.5, 0, 1), outline-width 0.75s cubic-bezier(0, 0.5, 0, 1), outline-color 0.75s cubic-bezier(0, 0.5, 0, 1);
  animation: none;
}
section.navigation nav menu li button#back-button::before {
  content: "🡰";
  content: "🡰"/"";
}
section.navigation nav menu li button#restart-button::before {
  content: "↶";
  content: "↶"/"";
}
section.navigation nav menu li button#reset-button::before {
  content: "⟲";
  content: "⟲"/"";
}
section.navigation nav menu li button#next-button::before {
  content: "🡲";
  content: "🡲"/"";
}
@media (hover: none) {
  section.navigation nav menu li button#restart-button, section.navigation nav menu li button#reset-button {
    --bottom-padding: calc(var(--nav-height) * .1);
    font-size: 12px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: calc(var(--nav-height) * 1.5);
    padding-bottom: var(--bottom-padding);
  }
  section.navigation nav menu li button#restart-button::before, section.navigation nav menu li button#reset-button::before {
    top: calc(var(--nav-height) * 0.1);
    font-size: calc(var(--nav-height) * 0.5);
    line-height: calc(var(--nav-height) * 0.5);
  }
  section.navigation nav menu li button#restart-button[hidden], section.navigation nav menu li button#reset-button[hidden] {
    display: none;
  }
}

@keyframes button-focus {
  from {
    background-color: var(--nav-button-bgr-focus-c);
  }
  to {
    background-color: var(--nav-button-bgr-c);
  }
}
@keyframes button-outline-focus {
  from {
    outline-color: hsla(var(--ci-color-HSL-frag)/0.7);
  }
  to {
    outline-color: hsla(var(--ci-color-HSL-frag)/0.2);
  }
}
section.menu {
  --top-bottom-padding: 10px;
  width: 100%;
  background-color: var(--outside-bgr-color);
  text-align: right;
}
section.menu menu {
  margin: 0;
  list-style: none;
}
section.menu menu li {
  display: inline-block;
  padding-top: var(--top-bottom-padding);
  padding-bottom: var(--top-bottom-padding);
  padding-left: 1.5ch;
  vertical-align: middle;
  line-height: 1;
  font-weight: 200;
  height: calc(var(--footer-menu-height) - 2 * var(--top-bottom-padding));
}
section.menu menu li:last-child::after {
  border-right-style: none;
}
section.menu menu li::after {
  content: "";
  display: inline-block;
  width: 1.5ch;
  height: calc(var(--footer-menu-height) - 2 * var(--top-bottom-padding));
  border-right-width: 1px;
  border-right-color: hsla(var(---structuring-color-HSL-frag)/0.3);
  border-right-style: solid;
  vertical-align: middle;
  opacity: 0.3;
}
section.menu menu li:focus-within {
  background-color: var(--nav-button-bgr-c);
}
section.menu menu li:focus-within a {
  color: var(--nav-button-text-focus-c);
  outline: none;
  text-shadow: 0px 1px 3px rgba(0, 0, 0, 0.4);
}
section.menu menu li a {
  color: var(--std-headline-color);
  line-height: calc(var(--footer-menu-height) - 2 * var(--top-bottom-padding));
  text-decoration: none;
}
section.menu menu li a:hover {
  text-decoration: underline;
}

section.details-container .detail {
  display: none;
}

section.questionnaire-container {
  position: relative;
  min-height: 100%;
  width: 100%;
}

fieldset.page {
  --hide-time: .3s;
  --show-time: .5s;
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  margin-top: 1em;
  opacity: 1;
  visibility: visible;
  transition: opacity var(--show-time) linear 0s, visibility 0s linear 0s, left var(--show-time) linear 0s;
  border-width: 1px;
  border-color: transparent;
  border-style: solid;
  border-image: linear-gradient(to right, hsla(var(--structuring-color-HSL-frag)/0.5) 0%, transparent 25%) 1;
  border-top-style: none;
  margin-bottom: var(--page-padding);
  margin-inline-start: 0px;
  margin-inline-end: px;
  padding-block-start: 0em;
  padding-inline-start: 0em;
  padding-inline-end: 0em;
  padding-block-end: 0em;
}
fieldset.page.ignored {
  display: none;
}
fieldset.page.hidden {
  left: -100%;
  opacity: 0;
  visibility: hidden;
  height: 0;
  overflow: hidden;
  transition: opacity var(--hide-time) linear 0s, visibility 0s linear var(--hide-time), height 0s linear var(--hide-time), overflow 0s linear var(--hide-time), left var(--hide-time) ease-in 0s;
}
fieldset.page.front {
  z-index: 20;
}
fieldset.page.new.hidden {
  left: 100%;
  transition: var(--hide-time) left 0s;
}
fieldset.page legend {
  padding-inline-start: 0px;
  padding: calc(var(--page-padding) / 2) var(--page-padding);
  top: 0;
  float: left;
  width: calc(100% - 2 * var(--page-padding));
  border-width: 1px;
  border-color: transparent;
  border-bottom-style: none;
  border-top-style: solid;
  border-image: linear-gradient(to right, hsla(var(--structuring-color-HSL-frag)/0.5) 0%, transparent 25%) 1;
  z-index: 4;
}
fieldset.page legend + * {
  clear: both;
}
fieldset.page legend h3.page-title {
  max-width: var(--max-line-length);
  color: var(--std-headline-color);
  font-family: var(--headline-ff);
  font-size: 1.5rem;
  font-weight: 300;
  letter-spacing: 0.02em;
  margin: 0;
  margin-bottom: 0.33em;
}
fieldset.page legend h3.page-title::before {
  content: "— ";
  opacity: 0.33;
}
fieldset.page legend span.explanation {
  display: block;
  max-width: var(--max-line-length);
  font-size: 90%;
  padding-left: 1.4em;
  font-weight: 100;
  color: var(--std-headline-color);
  margin-bottom: 0.5em;
}
fieldset.page legend:has(+ .question-container > div.question:only-of-type) {
  display: none;
}
fieldset.page .question-container {
  padding: var(--page-padding);
  --output-width: 8ch;
  border-width: 1px;
  border-color: transparent;
  border-bottom-style: none;
  border-top-style: solid;
  border-image: linear-gradient(to right, hsla(var(--structuring-color-HSL-frag)/0.5) 0%, transparent 25%) 1;
  width: calc(100% - 2 * var(--page-padding));
  position: relative;
}
fieldset.page .question-container .question {
  width: 100%;
  --additional-spacing: 5px;
}
fieldset.page .question-container .question output {
  background-color: var(--advanced-live-field-bgr-c);
  color: var(--advanced-live-field-text-c);
  position: absolute;
  bottom: 0;
  right: 0;
  width: calc(100% - 1.5ch);
  line-height: var(--checkbox-size);
  text-align: right;
  padding-right: 1.5ch;
  font-size: 1rem;
  padding-bottom: 0.75em;
  padding-top: 0.75em;
}
fieldset.page .question-container .question.finder + .question {
  margin-top: 3em;
}
fieldset.page .question-container .question.ignored {
  display: none;
}
fieldset.page .question-container .question .option label {
  display: inline-block;
  cursor: pointer;
}
fieldset.page .question-container .question .option input[type=checkbox],
fieldset.page .question-container .question .option input[type=radio] {
  cursor: pointer;
}
fieldset.page .question-container .question.finder {
  display: grid;
  width: 100%;
  grid-template-rows: min-content min-content;
  grid-gap: 2em;
  justify-content: stretch;
}
fieldset.page .question-container .question.finder:has(.data-switch-container) {
  grid-gap: 0.5em;
}
fieldset.page .question-container .question header {
  position: sticky;
  top: calc(-1 * var(--window-padding));
  padding: calc(var(--page-padding) / 2);
  padding-left: 1.5ch;
  color: var(--question-header-text-c);
  background-color: var(--question-header-bgr-c);
  z-index: 100;
  border-width: var(--additional-spacing);
  border-style: solid;
  border-color: var(--std-bgr-color);
}
@supports (-webkit-backdrop-filter: blur(2em)) or (backdrop-filter: blur(2em)) {
  fieldset.page .question-container .question header {
    background-color: var(--question-header-bgr-backdrop-c);
    backdrop-filter: blur(12px);
  }
}
fieldset.page .question-container .question header h4.question-title {
  margin-top: 0;
  margin-bottom: 0.25em;
  font-weight: normal;
  font-size: 1.5rem;
}
fieldset.page .question-container .question header .explanation {
  font-weight: 200;
}
fieldset.page .question-container .question dl.options {
  display: grid;
  grid-template-columns: calc(var(--checkbox-size) * 1.5) calc(100% - var(--checkbox-size) * 1.5);
  grid-auto-flow: dense;
  gap: 1.5em 0;
  margin: 1.5em 5px;
  justify-items: stretch;
  align-items: stretch;
  justify-content: stretch;
  align-content: stretch;
}
fieldset.page .question-container .question dl.options.ignored {
  display: none;
}
fieldset.page .question-container .question dl.options.radio {
  gap: 0;
}
fieldset.page .question-container .question dl.options.radio div.live-output {
  display: grid;
  grid-column: 1/span 2;
  grid-template-columns: calc(100% - var(--output-width)) var(--output-width);
  background-color: var(--option-accent-bgr-c);
}
fieldset.page .question-container .question dl.options.radio div.live-output dt.label-box {
  grid-column-start: 1;
  text-align: right;
  width: calc(100% - 1ch);
  padding-right: 1ch;
  justify-content: flex-end;
  align-content: flex-end;
  background-color: transparent;
}
fieldset.page .question-container .question dl.options.radio div.live-output dd.output-box {
  grid-column-start: 2;
  position: relative;
}
fieldset.page .question-container .question dl.options.checkboxes.advanced-live {
  grid-template-columns: calc(var(--checkbox-size) * 1.5) calc(100% - var(--checkbox-size) * 1.5 - var(--output-width)) var(--output-width);
}
fieldset.page .question-container .question dl.options.checkboxes.advanced-live dd.live-output {
  grid-column-start: 3;
  justify-self: stretch;
  background-color: var(--option-accent-bgr-c);
  align-self: stretch;
  position: relative;
  padding-top: 0;
  padding-bottom: 0;
}
fieldset.page .question-container .question dl.options.checkboxes.advanced-live dd.live-output label {
  visibility: hidden;
  font-size: 0;
}
fieldset.page .question-container .question dl.options.checkboxes.advanced-live dt.advanced-live-override {
  grid-column-start: 2;
  grid-column-end: 4;
}
fieldset.page .question-container .question dl.options dt {
  grid-column-start: 2;
  margin: 0;
  padding: 0.75em 0;
  background-color: var(--option-accent-bgr-c);
  padding-right: 2ch;
  display: flex;
  align-items: center;
  height: fit-content;
  min-height: var(--checkbox-size);
}
fieldset.page .question-container .question dl.options dt.ignored {
  display: none;
}
fieldset.page .question-container .question dl.options dt label {
  --local-font-size-increase: 1.15;
  font-size: calc(var(--local-font-size-increase) * 100%);
  font-family: var(--ff-sans-ch);
  max-width: var(--max-line-length);
  height: fit-content;
  cursor: pointer;
  display: inline-block;
}
fieldset.page .question-container .question dl.options dt label span.clarification {
  display: block;
  font-size: 90%;
  font-weight: 200;
  line-height: 1.2;
  max-width: var(--max-line-length);
}
fieldset.page .question-container .question dl.options dt label span.clarification span.list {
  display: block;
  margin-top: 0.6em;
  padding-left: 2ch;
}
fieldset.page .question-container .question dl.options dt label span.clarification span.list span.li {
  display: list-item;
  line-height: 1.8;
}
fieldset.page .question-container .question dl.options dt label span.clarification span.list span.li::marker {
  content: "· ";
  display: inline;
}
fieldset.page .question-container .question dl.options dd {
  grid-column-start: 1;
  margin: 0;
  padding: 0;
  justify-self: stretch;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  background-color: var(--option-accent-bgr-c);
  text-align: center;
  font-size: 0;
}
fieldset.page .question-container .question dl.options dd.ignored {
  display: none;
}
fieldset.page .question-container .question div.option.sub-values {
  padding-left: var(--page-padding);
  margin-top: 2em;
  padding-top: 0.75em;
  padding-bottom: 0.75em;
  margin-left: 5px;
  margin-right: 5px;
  margin-bottom: 1.5em;
  background-color: var(--option-accent-bgr-c);
}
fieldset.page .question-container .question div.option.sub-values.ignored {
  display: none;
}
fieldset.page .question-container .question div.option.sub-values:last-child {
  margin-bottom: 3em;
}
fieldset.page .question-container .question div.option.sub-values.advanced-live {
  padding-bottom: 0;
}
fieldset.page .question-container .question div.option.sub-values.advanced-live.hide-status-display .header .status-display {
  display: none;
}
fieldset.page .question-container .question div.option.sub-values.advanced-live ul.sub-options {
  margin-bottom: 1em;
}
fieldset.page .question-container .question div.option.sub-values .header {
  display: grid;
  grid-template-columns: auto auto;
  grid-template-rows: auto auto auto;
  grid-template-areas: "headline indicator" "instruction instruction" "status status";
}
fieldset.page .question-container .question div.option.sub-values .header h4.item-title {
  grid-area: headline;
  font-family: var(--copy-ff);
  font-size: 115%;
  grid-area: headline;
  margin-bottom: 0;
  margin-top: 0;
  max-width: var(--max-line-length);
  font-weight: normal;
}
fieldset.page .question-container .question div.option.sub-values .header .item-indicator {
  grid-area: indicator;
}
fieldset.page .question-container .question div.option.sub-values .header p.instruction {
  grid-area: instruction;
  opacity: 0.5;
  margin-bottom: 0;
  max-width: var(--max-line-length);
  font-size: 90%;
}
fieldset.page .question-container .question div.option.sub-values .header .status-display {
  grid-area: status;
  max-width: var(--max-line-length);
  display: grid;
  grid-template-areas: "main";
}
fieldset.page .question-container .question div.option.sub-values .header .status-display p.status {
  position: relative;
  grid-area: main;
  width: fit-content;
  padding-left: 3ch;
  mask-image: linear-gradient(to right, rgb(255, 255, 255) 0%, rgb(255, 255, 255) 33.33%, rgba(255, 255, 255, 0) 66.66%, rgba(255, 255, 255, 0) 100%);
  mask-size: 300% 100%;
  mask-position: 0% 0%;
  pointer-events: all;
  visibility: visible;
  transition: mask-position 1s ease-in-out, visibility 0s linear 0s;
}
fieldset.page .question-container .question div.option.sub-values .header .status-display p.status::before {
  display: inline-block;
  position: absolute;
  left: 3ch;
  transform: translateX(-100%);
  content: "— ";
}
fieldset.page .question-container .question div.option.sub-values .header .status-display p.status.hidden {
  visibility: hidden;
  mask-position: 100% 0%;
  pointer-events: none;
  transition: mask-position 1s ease-in-out, visibility 0s linear 1s;
}
fieldset.page .question-container .question div.option.sub-values .header .status-display.prefixed p.status .main {
  font-weight: bold;
}
fieldset.page .question-container .question div.option.sub-values .header .status-display.prefixed p.status::before {
  content: "🡲  ";
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: calc(var(--checkbox-size) * 1.5) auto;
  grid-auto-rows: min-content;
  grid-auto-flow: dense;
  gap: 1em 0.5em;
  list-style: none;
  --checkbox-size: calc(var(--checkbox-base-size) / 1.25);
  margin-top: 0.5em;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li {
  display: contents;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled label {
  position: relative;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled label,
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled input {
  opacity: 0.66;
  cursor: not-allowed;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled label .hint.geo-controlled,
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled input .hint.geo-controlled {
  padding: 0.5em;
  opacity: 0.66;
  display: block;
  font-size: 85%;
  font: 200;
  margin-bottom: 0.5em;
  margin-top: 0.5em;
  padding-left: 3ch;
  background-color: transparent;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled label .hint.geo-controlled::before,
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled input .hint.geo-controlled::before {
  content: "⚠";
  position: absolute;
  left: 0.5em;
  display: block;
  color: var(--neutral-color);
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled label:hover .hint.geo-controlled,
fieldset.page .question-container .question div.option.sub-values ul.sub-options li.geo-remote-controlled input:hover .hint.geo-controlled {
  opacity: 1;
  transition: opacity 0.5s ease-in-out;
  background-color: white;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label {
  grid-column-start: 2;
  display: inline-block;
  max-width: var(--max-line-length);
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label.ignored {
  display: none;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label:has(.clarification) {
  width: fit-content;
  padding-right: 4ch;
  position: relative;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label:has(.clarification) .value-display {
  position: absolute;
  right: 0;
  top: 0;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label span.clarification {
  display: block;
  font-size: 90%;
  font-weight: 200;
  line-height: 1.2;
  max-width: var(--max-line-length);
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label span.clarification span.list {
  display: block;
  margin-top: 0.6em;
  padding-left: 2ch;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label span.clarification span.list span.li {
  display: list-item;
  line-height: 1.8;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li label span.clarification span.list span.li::marker {
  content: "· ";
  display: inline;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li input {
  grid-column-start: 1;
  margin: 0;
  padding: 0;
  justify-self: center;
}
fieldset.page .question-container .question div.option.sub-values ul.sub-options li input.ignored {
  display: none;
}
fieldset.page .question-container .question div.option.sub-values div.live-output {
  display: grid;
  grid-column: 1/span 2;
  grid-template-columns: calc(100% - var(--output-width)) var(--output-width);
}
fieldset.page .question-container .question div.option.sub-values div.live-output dt.label-box {
  grid-column-start: 1;
  text-align: right;
  width: calc(100% - 1ch - 5ch);
  padding-right: 1ch;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  align-content: flex-end;
  padding: 0.75em 0;
  padding-left: 5ch;
  height: fit-content;
  min-height: var(--checkbox-size);
}
fieldset.page .question-container .question div.option.sub-values div.live-output dd.output-box {
  grid-column-start: 2;
  position: relative;
  justify-self: stretch;
  align-self: stretch;
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  margin: 0;
}
fieldset.page .question-container .question div.option.sub-values div.live-output dd.output-box label {
  color: transparent;
  font-size: 0;
  width: 0;
  height: 0;
  display: inline-block;
}

dialog {
  --side-padding: clamp(var(--window-padding), 5vw, 3rem);
  width: calc(var(--max-body-width) - 2 * var(--side-padding));
  border: none;
  padding: 0;
  box-shadow: 0 0 0px 0px rgba(0, 0, 0, 0);
  display: block;
  visibility: hidden;
  opacity: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}
dialog::backdrop {
  backdrop-filter: blur(0px);
}
dialog[open] {
  visibility: visible;
  opacity: 1;
  box-shadow: 0 0 10px 3px rgba(0, 0, 0, 0.15);
  height: fit-content;
  overflow: auto;
  pointer-events: all;
  transition: visibility 0s linear 0s, opacity 0.75s ease-out 0s, box-shadow 0.75s ease-out 0s;
}
dialog[open]::backdrop {
  backdrop-filter: blur(5px);
  transition: backdrop-filter 0.5s linear 0s;
}
dialog header {
  background-color: var(--inverted-bgr-intense-color);
  color: var(--inverted-text-color);
  border-bottom: solid 1px var(--structuring-color);
  padding: 0.5em;
  position: relative;
}
dialog header button.close {
  position: absolute;
  right: 0;
  top: 0;
  background-color: var(--dialog-close-button-bgr-c);
  appearance: none;
  border: none;
  cursor: pointer;
  height: 100%;
  aspect-ratio: 1;
  font-size: 1.5em;
  line-height: 1;
  color: var(--inverted-text-color);
  appearance: none;
  border: none;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}
dialog header button.close:hover {
  background-color: var(--dialog-close-button-hover-bgr-c);
  transition: all 0.5s ease-in-out;
}
dialog header button.close:focus {
  outline: none;
}
dialog header button.close:focus-visible {
  outline: solid 2px var(--dialog-close-button-outline-c);
}
dialog header h2 {
  margin: 0;
  font-size: 1.2rem;
  font-weight: 300;
  color: var(--inverted-text-color);
}
dialog header h2::before {
  content: "⚠ ";
  color: var(--dialog-header-icon-default-c);
}
dialog section.main {
  padding: 2rem;
  padding-bottom: 0;
}
dialog section.main h2 {
  font-size: 1.5rem;
  font-weight: 500;
  margin: 0;
  margin-bottom: 1rem;
}
dialog form.buttons {
  max-width: 400px;
  margin: 0 auto;
  padding: 2rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10ch, 1fr));
  gap: 1em;
}
dialog form.buttons button {
  appearance: none;
  border: solid 1px var(--structuring-color);
  font: inherit;
  padding: 0.5em;
  font-size: 1.2rem;
  background-color: var(--bf-button-bgr-c);
  color: var(--bf-button-text-c);
  cursor: pointer;
  transition: all 0.5s ease-out 0s;
}
dialog form.buttons button:hover {
  background-color: var(--inverted-bgr-intense-color);
  color: var(--inverted-text-color);
}
dialog.information header, dialog.hint header, dialog.notice header {
  background-color: var(--dialog-header-bgr-neutral-c);
}
dialog.information header h2::before, dialog.hint header h2::before, dialog.notice header h2::before {
  content: "🛈 ";
  color: var(--dialog-header-icon-neutral-c);
}
dialog.notice header h2::before {
  content: "⚠ ";
}
dialog.warning header {
  background-color: var(--dialog-header-bgr-warn-c);
}
dialog.warning header h2::before {
  content: "⚠ ";
  color: var(--dialog-header-icon-warn-c);
}

section.basic-info-container.closed #basic-info-display .info button.base-info-hint {
  appearance: none;
  border: none;
  background-color: var(--baseinfo-hint-icon-bgr-default-c);
  color: var(--baseinfo-hint-icon-default-c);
  border-radius: 50%;
  font-size: 1.2rem;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 1.6rem;
  text-align: center;
  aspect-ratio: 1;
  cursor: pointer;
  margin-right: 1ch;
  transition: all 0.5s ease-out 0s;
  position: relative;
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint:hover {
  color: var(--baseinfo-hint-icon-default-hover-c);
  background-color: var(--baseinfo-hint-icon-bgr-default-hover-c);
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint:focus {
  outline: none;
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint:focus-visible {
  outline: solid 2px var(--baseinfo-hint-icon-default-outline-c);
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint span {
  position: relative;
  top: -0.1em;
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint.warning {
  background-color: var(--baseinfo-hint-icon-bgr-warn-c);
  color: var(--baseinfo-hint-icon-warn-c);
}
section.basic-info-container.closed #basic-info-display .info button.base-info-hint.warning:hover {
  background-color: var(--baseinfo-hint-icon-bgr-warn-hover-c);
  color: var(--baseinfo-hint-icon-warn-hover-c);
}

body.reporting-active section.basic-info-container.closed #basic-info-display .info button.base-info-hint {
  pointer-events: none;
}

#reporting-container {
  --finder-main-line-font-weight: 500;
  --finder-main-line-font-size: 100%;
  --finder-main-line-font-color: currentcolor;
  --finder-sub-line-font-weight: 300;
  --finder-sub-line-font-size: 90%;
  --finder-sub-line-font-color: hsla(var(--std-text-color-HSL-frag)/0.6);
  --show-time: 0.5s;
  position: absolute;
  min-height: calc(100% - 2 * var(--window-padding));
  top: calc(-1 * var(--window-padding));
  left: calc(100% + var(--window-padding) * 2);
  width: calc(100% - 2 * var(--window-padding));
  padding: calc(2 * var(--window-padding));
  background-color: var(--reporting-bgr-color);
  z-index: 100;
  transition: left var(--show-time) ease-in 0s;
}
#reporting-container.open {
  left: calc(-1 * var(--window-padding));
  transition: left var(--show-time) ease-in 0s;
}
#reporting-container table#reporting-table {
  --cell-padding: .5em;
  width: 100%;
  background-color: var(--reporting-bgr-color);
  border-collapse: collapse;
}
#reporting-container table#reporting-table *.no-reporting {
  display: none;
}
#reporting-container table#reporting-table td {
  background-clip: padding-box;
}
#reporting-container table#reporting-table td span.asterisk {
  display: none;
}
#reporting-container table#reporting-table caption {
  background-color: var(--ci-color);
  color: var(--std-bgr-color);
  caption-side: top;
  font-family: var(--headline-ff);
  font-weight: 100;
  font-size: 1.75em;
  line-height: 2.5em;
  letter-spacing: 0.02em;
}
#reporting-container table#reporting-table caption::before {
  content: "— ";
}
#reporting-container table#reporting-table caption::after {
  content: " —";
}
#reporting-container table#reporting-table thead.reporting-base-info tr th {
  background-color: hsla(var(--structuring-color-HSL-frag)/0.3);
  text-align: left;
  padding: var(--cell-padding);
}
#reporting-container table#reporting-table thead.reporting-base-info tr th > span {
  padding-right: 4ch;
  white-space: nowrap;
}
#reporting-container table#reporting-table thead.reporting-base-info tr th > span span.naming {
  font-weight: 100;
}
#reporting-container table#reporting-table thead.reporting-base-info tr th > span span.naming::after {
  content: ": ";
}
#reporting-container table#reporting-table tbody tr:last-child td:not(:last-child) {
  border-bottom: 0em solid transparent;
}
#reporting-container table#reporting-table tbody tr.page:first-child th.reporting-page-title {
  padding-top: 3em;
}
#reporting-container table#reporting-table tbody tr.page th.reporting-page-title {
  padding-top: 2em;
  max-width: var(--max-line-length);
  color: var(--std-headline-color);
  font-family: var(--headline-ff);
  font-size: 0.9rem;
  font-weight: 300;
  letter-spacing: 0.02em;
  padding-bottom: 0.5em;
  text-align: left;
}
#reporting-container table#reporting-table tr.question td {
  font-size: 125%;
  font-weight: 500;
  padding-bottom: 0.1em;
  border-bottom-style: solid;
  border-bottom-width: 2px;
  border-bottom-color: var(--structuring-color);
}
#reporting-container table#reporting-table tr.question td.reporting-question-title span.inner {
  background-color: transparent;
}
#reporting-container table#reporting-table tr.question td.reporting-question-value {
  text-align: right;
  padding-right: 1ch;
}
#reporting-container table#reporting-table tr.question td.reporting-question-value span.inner {
  background-color: transparent;
}
#reporting-container table#reporting-table tr.question + tr.option td {
  padding-top: 1.25em;
}
#reporting-container table#reporting-table tr.option + tr.question td {
  padding-top: 1em;
}
#reporting-container table#reporting-table tr.option.empty {
  display: none;
}
#reporting-container table#reporting-table tr.option.summary + tr.empty {
  display: table-row;
}
#reporting-container table#reporting-table tr.option.group-header td.finder-result.reporting-option-description,
#reporting-container table#reporting-table tr.option.group-header td.finder-result.reporting-option-value {
  font-weight: var(--finder-main-line-font-weight);
  font-size: var(--finder-main-line-font-size);
  border-bottom-color: var(--finder-sub-line-font-color);
}
#reporting-container table#reporting-table tr.option.group-header td.finder-result.reporting-option-description.finder-result.no-options,
#reporting-container table#reporting-table tr.option.group-header td.finder-result.reporting-option-value.finder-result.no-options {
  border-bottom-width: 1px;
  border-bottom-style: none;
}
#reporting-container table#reporting-table tr.option.group-header td.finder-result.reporting-option-description {
  color: var(--finder-main-line-font-color);
}
#reporting-container table#reporting-table tr.option.group-header + tr.group-line td {
  padding-top: 0.5em;
}
#reporting-container table#reporting-table tr.option td.reporting-option-description {
  padding-left: 2ch;
  font-weight: 100;
  line-height: 1.5;
  max-width: var(--max-line-length);
  position: relative;
  background-color: var(--reporting-bgr-color);
}
#reporting-container table#reporting-table tr.option td.reporting-option-description:before {
  content: "";
  position: absolute;
  width: calc(100% - 2ch - 3px);
  height: 0;
  border-bottom: 1px dotted hsla(var(--std-text-color-HSL-frag)/0.25);
  bottom: calc(0.75em + 6px);
}
#reporting-container table#reporting-table tr.option td.reporting-option-description span.inner {
  background-color: inherit;
  position: relative;
  z-index: 2;
  padding-right: 3px;
}
#reporting-container table#reporting-table tr.option td.finder-result.explanation {
  padding-bottom: 1em;
}
#reporting-container table#reporting-table tr.option td.finder-result.singel-value {
  font-weight: var(--finder-main-line-font-weight);
  font-size: var(--finder-main-line-font-size);
  color: var(--finder-main-line-font-color);
}
#reporting-container table#reporting-table tr.option td.reporting-option-value {
  color: hsla(var(--std-text-color-HSL-frag)/0.5);
  vertical-align: bottom;
  text-align: right;
}
#reporting-container table#reporting-table tr.option td {
  padding-bottom: 0.75em;
}
#reporting-container table#reporting-table tr.sub-option.group-line td.reporting-sub-option-description {
  font-weight: var(--finder-sub-line-font-weight);
}
#reporting-container table#reporting-table tr.sub-option.group-line td {
  padding-bottom: 0.75em;
  font-size: var(--finder-sub-line-font-size);
}
#reporting-container table#reporting-table tr.sub-option.group-line:last-of-type td {
  padding-bottom: 1em;
}
#reporting-container table#reporting-table tr.sub-option td.reporting-sub-option-description {
  position: relative;
  top: -0.25em;
  padding-left: 5ch;
  font-size: 90%;
  font-weight: 300;
  color: hsla(var(--std-text-color-HSL-frag)/0.6);
  padding-bottom: 0.33em;
  vertical-align: bottom;
}
#reporting-container table#reporting-table tr.sub-option td.reporting-sub-option-description span.inner::before {
  content: "– ";
  position: absolute;
  transform: translatex(-100%);
}
#reporting-container table#reporting-table tr.sub-option td.reporting-option-value {
  color: hsla(var(--std-text-color-HSL-frag)/0.5);
  vertical-align: bottom;
  text-align: right;
  top: -0.25em;
  padding-bottom: 0.33em;
}
#reporting-container tfoot {
  border-top: 1.5em transparent solid;
}
#reporting-container tfoot tr.correction-sum td {
  padding-top: 0.5em;
  background-color: hsla(var(--structuring-color-HSL-frag)/0.3);
  padding-bottom: 0.5em;
  font-size: 125%;
  font-weight: 500;
  padding-left: 1ch;
}
#reporting-container tfoot tr.correction-sum td.correction-sum-value {
  border-top: 2px solid var(--ci-color);
  text-align: right;
  padding-right: 1ch;
  position: relative;
}
#reporting-container tfoot tr.correction-sum td.correction-sum-value:after, #reporting-container tfoot tr.correction-sum td.correction-sum-value::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 2px;
  right: 0;
  top: 0px;
  background-color: var(--ci-color);
}
#reporting-container tfoot tr.correction-sum td.correction-sum-value::after {
  top: 4px;
}
#reporting-container tfoot tr.summary-header-row th.summary-header {
  padding-top: 3em;
  color: var(--std-headline-color);
  font-family: var(--headline-ff);
  font-weight: 300;
  letter-spacing: 0.02em;
  padding-bottom: 1.5em;
  font-size: 120%;
}
#reporting-container tfoot tr.summary-header-row th.summary-header::before {
  content: "— ";
}
#reporting-container tfoot tr.summary-header-row th.summary-header::after {
  content: " —";
}
#reporting-container tfoot tr td.summary-sqm-wording,
#reporting-container tfoot tr td.summary-area-wording,
#reporting-container tfoot tr td.summary-area-year-wording,
#reporting-container tfoot tr td.span-area-wording,
#reporting-container tfoot tr td.span-sqm-wording,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording,
#reporting-container tfoot tr td.summary-correction-percentage-wording,
#reporting-container tfoot tr td.summary-correction-sum-wording {
  background-color: var(--reporting-bgr-color);
  position: relative;
  vertical-align: bottom;
  font-size: 110%;
  line-height: 1.6;
  padding-bottom: 0.5em;
}
#reporting-container tfoot tr td.summary-sqm-wording:before,
#reporting-container tfoot tr td.summary-area-wording:before,
#reporting-container tfoot tr td.summary-area-year-wording:before,
#reporting-container tfoot tr td.span-area-wording:before,
#reporting-container tfoot tr td.span-sqm-wording:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording:before,
#reporting-container tfoot tr td.summary-correction-percentage-wording:before,
#reporting-container tfoot tr td.summary-correction-sum-wording:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 0;
  border-bottom: 1px dotted hsla(var(--std-text-color-HSL-frag)/0.25);
  bottom: calc(0.5em + 6px);
}
#reporting-container tfoot tr td.summary-sqm-wording span.inner,
#reporting-container tfoot tr td.summary-area-wording span.inner,
#reporting-container tfoot tr td.summary-area-year-wording span.inner,
#reporting-container tfoot tr td.span-area-wording span.inner,
#reporting-container tfoot tr td.span-sqm-wording span.inner,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording span.inner,
#reporting-container tfoot tr td.summary-correction-percentage-wording span.inner,
#reporting-container tfoot tr td.summary-correction-sum-wording span.inner {
  background-color: inherit;
  position: relative;
  padding-right: 3px;
  z-index: 2;
}
#reporting-container tfoot tr td.summary-sqm-wording.footnote, #reporting-container tfoot tr td.summary-sqm-wording[colspan="3"],
#reporting-container tfoot tr td.summary-area-wording.footnote,
#reporting-container tfoot tr td.summary-area-wording[colspan="3"],
#reporting-container tfoot tr td.summary-area-year-wording.footnote,
#reporting-container tfoot tr td.summary-area-year-wording[colspan="3"],
#reporting-container tfoot tr td.span-area-wording.footnote,
#reporting-container tfoot tr td.span-area-wording[colspan="3"],
#reporting-container tfoot tr td.span-sqm-wording.footnote,
#reporting-container tfoot tr td.span-sqm-wording[colspan="3"],
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording.footnote,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording[colspan="3"],
#reporting-container tfoot tr td.summary-correction-percentage-wording.footnote,
#reporting-container tfoot tr td.summary-correction-percentage-wording[colspan="3"],
#reporting-container tfoot tr td.summary-correction-sum-wording.footnote,
#reporting-container tfoot tr td.summary-correction-sum-wording[colspan="3"] {
  padding-top: 1em;
  font-size: 95%;
  white-space: normal;
  text-align: left;
}
#reporting-container tfoot tr td.summary-sqm-wording.footnote:before, #reporting-container tfoot tr td.summary-sqm-wording[colspan="3"]:before,
#reporting-container tfoot tr td.summary-area-wording.footnote:before,
#reporting-container tfoot tr td.summary-area-wording[colspan="3"]:before,
#reporting-container tfoot tr td.summary-area-year-wording.footnote:before,
#reporting-container tfoot tr td.summary-area-year-wording[colspan="3"]:before,
#reporting-container tfoot tr td.span-area-wording.footnote:before,
#reporting-container tfoot tr td.span-area-wording[colspan="3"]:before,
#reporting-container tfoot tr td.span-sqm-wording.footnote:before,
#reporting-container tfoot tr td.span-sqm-wording[colspan="3"]:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording.footnote:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-wording[colspan="3"]:before,
#reporting-container tfoot tr td.summary-correction-percentage-wording.footnote:before,
#reporting-container tfoot tr td.summary-correction-percentage-wording[colspan="3"]:before,
#reporting-container tfoot tr td.summary-correction-sum-wording.footnote:before,
#reporting-container tfoot tr td.summary-correction-sum-wording[colspan="3"]:before {
  display: none;
  border-bottom: none;
}
#reporting-container tfoot tr td.summary-sqm-value,
#reporting-container tfoot tr td.summary-area-value,
#reporting-container tfoot tr td.summary-area-year-value,
#reporting-container tfoot tr td.span-area-values,
#reporting-container tfoot tr td.span-sqm-values,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value,
#reporting-container tfoot tr td.summary-correction-percentage-value,
#reporting-container tfoot tr td.summary-correction-sum-value {
  background-color: var(--reporting-bgr-color);
  position: relative;
  white-space: nowrap;
  word-break: keep-all;
  width: max-content;
  max-width: 90vw;
  text-align: right;
  font-size: 110%;
  line-height: 1.6;
  padding-bottom: 0.5em;
  vertical-align: bottom;
}
#reporting-container tfoot tr td.summary-sqm-value:before,
#reporting-container tfoot tr td.summary-area-value:before,
#reporting-container tfoot tr td.summary-area-year-value:before,
#reporting-container tfoot tr td.span-area-values:before,
#reporting-container tfoot tr td.span-sqm-values:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value:before,
#reporting-container tfoot tr td.summary-correction-percentage-value:before,
#reporting-container tfoot tr td.summary-correction-sum-value:before {
  content: "";
  position: absolute;
  width: 100%;
  height: 0;
  right: 0;
  border-bottom: 1px dotted hsla(var(--std-text-color-HSL-frag)/0.25);
  bottom: calc(0.5em + 6px);
}
#reporting-container tfoot tr td.summary-sqm-value span.inner,
#reporting-container tfoot tr td.summary-area-value span.inner,
#reporting-container tfoot tr td.summary-area-year-value span.inner,
#reporting-container tfoot tr td.span-area-values span.inner,
#reporting-container tfoot tr td.span-sqm-values span.inner,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value span.inner,
#reporting-container tfoot tr td.summary-correction-percentage-value span.inner,
#reporting-container tfoot tr td.summary-correction-sum-value span.inner {
  background-color: inherit;
  position: relative;
  padding-left: 3px;
  z-index: 2;
}
#reporting-container tfoot tr td.summary-sqm-value.footnote, #reporting-container tfoot tr td.summary-sqm-value[colspan="3"],
#reporting-container tfoot tr td.summary-area-value.footnote,
#reporting-container tfoot tr td.summary-area-value[colspan="3"],
#reporting-container tfoot tr td.summary-area-year-value.footnote,
#reporting-container tfoot tr td.summary-area-year-value[colspan="3"],
#reporting-container tfoot tr td.span-area-values.footnote,
#reporting-container tfoot tr td.span-area-values[colspan="3"],
#reporting-container tfoot tr td.span-sqm-values.footnote,
#reporting-container tfoot tr td.span-sqm-values[colspan="3"],
#reporting-container tfoot tr td.summary-baserent-per-sqm-value.footnote,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value[colspan="3"],
#reporting-container tfoot tr td.summary-correction-percentage-value.footnote,
#reporting-container tfoot tr td.summary-correction-percentage-value[colspan="3"],
#reporting-container tfoot tr td.summary-correction-sum-value.footnote,
#reporting-container tfoot tr td.summary-correction-sum-value[colspan="3"] {
  padding-top: 1em;
  font-size: 95%;
  white-space: normal;
  text-align: left;
}
#reporting-container tfoot tr td.summary-sqm-value.footnote:before, #reporting-container tfoot tr td.summary-sqm-value[colspan="3"]:before,
#reporting-container tfoot tr td.summary-area-value.footnote:before,
#reporting-container tfoot tr td.summary-area-value[colspan="3"]:before,
#reporting-container tfoot tr td.summary-area-year-value.footnote:before,
#reporting-container tfoot tr td.summary-area-year-value[colspan="3"]:before,
#reporting-container tfoot tr td.span-area-values.footnote:before,
#reporting-container tfoot tr td.span-area-values[colspan="3"]:before,
#reporting-container tfoot tr td.span-sqm-values.footnote:before,
#reporting-container tfoot tr td.span-sqm-values[colspan="3"]:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value.footnote:before,
#reporting-container tfoot tr td.summary-baserent-per-sqm-value[colspan="3"]:before,
#reporting-container tfoot tr td.summary-correction-percentage-value.footnote:before,
#reporting-container tfoot tr td.summary-correction-percentage-value[colspan="3"]:before,
#reporting-container tfoot tr td.summary-correction-sum-value.footnote:before,
#reporting-container tfoot tr td.summary-correction-sum-value[colspan="3"]:before {
  display: none;
  border-bottom: none;
}
#reporting-container tfoot tr.summary-area + tr:not(.summary-area-year) td {
  padding-top: 2.5em;
}
#reporting-container tfoot tr.summary-area-year + tr td {
  padding-top: 2.5em;
}
#reporting-container tfoot tr#accuracy-annotation⚠ td.info h5 {
  font-family: var(--copy-ff);
  margin-bottom: 0.25em;
  margin-top: 4em;
}
#reporting-container tfoot tr#accuracy-annotation⚠ td.info p {
  margin-top: 0;
  font-size: 75%;
  margin-bottom: 0.5em;
}
#reporting-container button {
  appearance: none;
  border: 1px solid var(--structuring-color);
  background-color: var(--reporting-bgr-color);
  color: var(--std-text-color);
  cursor: pointer;
  line-height: 1.5em;
  text-align: center;
  display: block;
  box-sizing: content-box;
  margin-left: auto;
  padding-top: 0.3em;
  padding-bottom: 0.3em;
  padding-left: 1em;
  padding-right: 1em;
  margin-top: 1em;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}
#reporting-container button:hover {
  background-color: var(--option-accent-bgr-c);
}

#report_of_rent_set_with_explanation {
  padding: 1em;
  border: solid 1px var(--structuring-color);
}
#report_of_rent_set_with_explanation #rent_set_adjustment {
  text-align: center;
}
#report_of_rent_set_with_explanation #rent_set_adjustment span.value {
  font-weight: 600;
}
#report_of_rent_set_with_explanation #set_rent_explanation h3 {
  font-size: 1rem;
  font-weight: 300;
  margin-top: 1em;
  margin-bottom: 0.5em;
  font-family: var(--copy-ff);
}
#report_of_rent_set_with_explanation #set_rent_explanation h3::after {
  content: ":";
}
#report_of_rent_set_with_explanation #set_rent_explanation p {
  margin-top: 0;
  margin-bottom: 1em;
}
#report_of_rent_set_with_explanation #rent_set_sqm_price,
#report_of_rent_set_with_explanation #rent_set_unit_price {
  margin-top: 1em;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1em;
}
#report_of_rent_set_with_explanation #rent_set_sqm_price span.description,
#report_of_rent_set_with_explanation #rent_set_unit_price span.description {
  font-size: 0.9rem;
  font-weight: 200;
  font-family: var(--copy-ff);
  display: block;
}
#report_of_rent_set_with_explanation #rent_set_sqm_price span.result,
#report_of_rent_set_with_explanation #rent_set_unit_price span.result {
  display: flex;
  justify-content: flex-end;
  font-weight: 600;
  text-align: right;
}

dialog.set-rent-with-explanation label {
  display: block;
  margin-bottom: 0.5em;
}
dialog.set-rent-with-explanation label span.label-text {
  font-weight: 600;
  font-size: 1.1rem;
  display: block;
}
dialog.set-rent-with-explanation label span#set_rent_allowed_span {
  display: block;
  font-size: 0.9em;
  font-weight: 200;
}
dialog.set-rent-with-explanation label input[type=number] {
  box-sizing: content-box;
  font-size: 1.1rem;
  padding: 0.3em;
  text-align: right;
  appearance: none;
  border: solid 1px var(--structuring-color);
  background-color: var(--reporting-bgr-color);
  color: var(--std-text-color);
}
dialog.set-rent-with-explanation label input[type=number]:focus {
  outline: none;
  border-color: var(--option-accent-bgr-c);
}
dialog.set-rent-with-explanation label input[type=number]:user-invalid ~ div.validation-error-msg,
dialog.set-rent-with-explanation label input[type=number]:invalid ~ div.validation-error-msg {
  visibility: visible;
}
dialog.set-rent-with-explanation label input[type=number]:placeholder-shown ~ div.validation-error-msg {
  visibility: hidden;
}
dialog.set-rent-with-explanation label div.validation-error-msg {
  visibility: hidden;
}
dialog.set-rent-with-explanation textarea {
  width: 100%;
  box-sizing: border-box;
  font-size: 1.1rem;
  padding: 0.3em;
  appearance: none;
  border: solid 1px var(--structuring-color);
  background-color: var(--reporting-bgr-color);
  color: var(--std-text-color);
}
dialog.set-rent-with-explanation textarea:focus {
  outline: none;
  border-color: var(--option-accent-bgr-c);
}
dialog.set-rent-with-explanation div.validation-error-msg {
  visibility: hidden;
  margin-bottom: 1em;
  background-color: var(--panic-color);
  color: var(--inverted-text-color);
  padding-top: 0.2em;
  padding-bottom: 0.3em;
  padding-left: 1ch;
  padding-right: 1ch;
  font-weight: 300;
  width: fit-content;
}
dialog.set-rent-with-explanation textarea:user-invalid + div.validation-error-msg {
  visibility: visible;
}

div#print-button-container {
  margin-top: 2em;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: fit-content;
  align-items: stretch;
  margin-right: 0;
  margin-left: auto;
}
div#print-button-container button,
div#print-button-container label {
  align-self: flex-end;
  flex-basis: content;
  flex-grow: 1;
  flex-shrink: 1;
}
div#print-button-container button {
  width: stretch;
  appearance: none;
  border: none;
  background-color: transparent;
  height: 4rem;
  font-size: 3em;
  line-height: 1.5em;
  text-align: center;
  color: var(--std-text-color);
  cursor: pointer;
  font-family: var(--ff-icons);
}

section#foot-notes {
  margin-top: 1em;
}
section#foot-notes div.foot-note {
  --padding: 1rem;
  background-color: hsla(var(--structuring-color-HSL-frag)/0.2);
  margin-bottom: 1em;
}
section#foot-notes div.foot-note hgroup div.over-head {
  padding: var(--padding);
  padding-top: calc(var(--padding) / 2);
  padding-bottom: calc(var(--padding) / 4);
  border-bottom: solid 1px var(--footnote-default-c);
}
section#foot-notes div.foot-note hgroup div.over-head:before {
  content: "🛈  ";
  font-size: 1.2em;
  color: var(--footnote-default-c);
}
section#foot-notes div.foot-note hgroup h2 {
  padding-left: var(--padding);
  padding-right: var(--padding);
  font-weight: 400;
  margin-top: 0.5em;
  margin-bottom: 0.25em;
  font-size: 1.4rem;
}
section#foot-notes div.foot-note .content {
  padding: var(--padding);
  padding-top: 0;
}
section#foot-notes div.foot-note .content p:first-of-type {
  margin-top: 0;
}
section#foot-notes div.foot-note.warning, section#foot-notes div.foot-note.hint, section#foot-notes div.foot-note.error {
  background-color: var(--footnote-warn-bgr-c);
}
section#foot-notes div.foot-note.warning hgroup div.over-head, section#foot-notes div.foot-note.hint hgroup div.over-head, section#foot-notes div.foot-note.error hgroup div.over-head {
  background-color: var(--footnote-warn-header-bgr-c);
  border-bottom-color: var(--footnote-warn-border-c);
}
section#foot-notes div.foot-note.warning hgroup div.over-head:before, section#foot-notes div.foot-note.hint hgroup div.over-head:before, section#foot-notes div.foot-note.error hgroup div.over-head:before {
  content: "⚠  ";
  color: var(--footnote-warn-icon-c);
}

#no-warranty {
  display: none;
}
#no-warranty h5 {
  margin-bottom: 0;
  font-family: var(--ff-sans);
  font-weight: 400;
  font-size: 1.1rem;
}
#no-warranty h5 span.attention-icon {
  padding-right: 1ch;
}
#no-warranty p {
  margin-top: 0.5em;
}

@media screen {
  #no-warranty.screen {
    display: block;
  }
}
@media print {
  #no-warranty.print {
    display: block;
  }
  div#print-button-container {
    display: none;
  }
}
span.value-display {
  font-weight: 100;
  opacity: 0.5;
  padding-left: 1ch;
  white-space: nowrap;
}

input[type=radio],
input[type=checkbox] {
  appearance: none;
  background-color: var(--std-bgr-color);
  background-image: url("../images/check_empty.svg");
  height: var(--checkbox-size);
  width: var(--checkbox-size);
  display: inline-block;
  vertical-align: text-bottom;
  position: relative;
  margin: 0;
  padding: 0;
}
input[type=radio]:focus,
input[type=checkbox]:focus {
  box-shadow: 0 0 5px 1px var(--checkbox-focus-color);
  outline: 3px solid var(--checkbox-focus-color);
  outline-offset: -2px;
  background-color: transparent;
  animation: focusAnim 2s ease-out 0.5s 1 normal forwards;
}
input[type=radio]:focus-visible,
input[type=checkbox]:focus-visible {
  box-shadow: 0 0 5px 1px var(--checkbox-focus-color);
  outline: 3px solid var(--checkbox-focus-color);
  outline-offset: -2px;
  background-color: transparent;
  animation: none;
}

@keyframes focusAnim {
  0% {
    outline: 3px solid var(--checkbox-focus-color);
    box-shadow: 0 0 5px 1px var(--checkbox-focus-color);
    background-color: transparent;
  }
  25% {
    outline: 3px solid transparent;
    box-shadow: 0 0 0px 0px var(--checkbox-focus-color);
    background-color: var(--checkbox-focus-color);
  }
  35% {
    background-color: var(--checkbox-focus-color);
  }
  100% {
    background-color: transparent;
    outline: 3px solid transparent;
    box-shadow: 0 0 0px 0px var(--checkbox-focus-color);
  }
}
input[type=radio] {
  border-radius: 100%;
  background-image: url("../images/radio_empty.svg");
}

input[type=checkbox]:checked {
  background-image: url("../images/check_checked.svg");
}

input[type=radio]:checked {
  background-image: url("../images/radio_checked.svg");
}

fieldset {
  all: unset;
}
fieldset legend {
  all: unset;
}

input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  appearance: none;
  margin: 0;
}

*::selection {
  background-color: hsl(var(--ci-color-HSL-frag)/0.75);
  color: var(--inverted-text-color);
}

input::selection {
  background-color: hsl(var(--bf-input-text-focus-c-HSL-frag)/0.5);
  color: var(--bf-input-text-c);
}

input[type=number] {
  appearance: textfield;
}

@page {
  size: A4;
  margin: 10mm 0 10mm 0;
}
@media print {
  :root {
    --std-bgr-color: white;
    --std-text-color: black;
    --std-headline-color: hsl(180, 15%, 25%);
    --structuring-color: gray;
    --page-margin-top: 10mm;
    --page-margin-right: 15mm;
    --page-margin-bottom: 10mm;
    --page-margin-left: 20mm;
    --page-margins: var(--page-margin-top) var(--page-margin-right) var(--page-margin-bottom) var(--page-margin-left);
    --header-height: 20mm;
    --page-width: 210mm;
    --page-height: 297mm;
  }
  html, body {
    width: calc(var(--page-width) - var(--page-margin-left) - var(--page-margin-right));
    height: calc(var(--page-height) - var(--page-margin-bottom) - var(--page-margin-top) - 20mm);
    background-color: var(--std-bgr-color);
    color: var(--std-text-color);
    font-size: 12pt;
  }
  html {
    width: var(--page-width);
    height: var(--page-height);
  }
  .no-print {
    display: none;
  }
  #reporting-container button.no-print {
    display: none;
  }
  body {
    margin: var(--page-margins);
  }
  body > header {
    background-color: var(--std-bgr-color);
    position: relative;
    max-width: calc(var(--page-width) - var(--page-margin-left) - var(--page-margin-right));
  }
  body > header h1 {
    font-size: 18pt;
    margin-top: 0;
  }
  body h1, body h2, body h3, body h4, body h5, body h6 {
    color: var(--std-headline-color);
  }
  body section.menu,
  body section.navigation,
  body section.basic-info-container {
    display: none;
  }
  body main {
    max-width: calc(var(--page-width) - var(--page-margin-left) - var(--page-margin-right));
    height: auto;
    border: none;
    overflow: visible;
  }
  body main div#window {
    position: relative;
    border: none;
    padding: 0;
    top: 0;
    scrollbar-gutter: unset;
  }
  body main div#window.reporting section.questionnaire-container form#questionnaire fieldset.page {
    display: none;
  }
  body main div#window.disabled {
    box-shadow: none;
  }
  body main div#window section.questionnaire-container {
    box-shadow: none;
  }
  body main div#window section.questionnaire-container form#questionnaire {
    filter: none;
    box-shadow: none;
  }
  body main div#window section.questionnaire-container form#questionnaire fieldset.page,
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container {
    margin-top: 0;
    border: none;
    position: relative;
  }
  body main div#window section.questionnaire-container form#questionnaire fieldset.page .question-container,
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container .question-container {
    padding: 0;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container {
    position: relative;
    left: 0;
    top: 0;
    padding: 0;
    width: 100%;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table {
    border-collapse: separate;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table caption {
    background-color: transparent;
    color: var(--std-text-color);
    font-size: 14pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table thead.reporting-base-info {
    width: calc(var(--page-width) - var(--page-margin-left) - var(--page-margin-right));
    position: relative;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table thead.reporting-base-info::after {
    content: "@";
    display: block;
    line-height: 2em;
    text-indent: -99999px;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table thead.reporting-base-info tr th {
    background-color: transparent;
    border: solid 1px var(--structuring-color);
    font-size: 11pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody {
    break-before: avoid-page;
    break-after: avoid-page;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.page {
    break-after: avoid-page;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.page th.reporting-page-title {
    opacity: 0.6;
    font-size: 9px;
    padding-top: 1em;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.page:first-child th.reporting-page-title {
    padding-top: 2em;
    padding-bottom: 0.2em;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.question {
    break-before: avoid-page;
    break-after: avoid-page;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.question td {
    border-bottom-width: 1px;
    border-bottom-style: dashed;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.question td.reporting-question-title {
    font-size: 13pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.question td.reporting-question-value {
    font-size: 13pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.option {
    break-before: avoid-page;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.option td {
    font-size: 11pt;
    padding-top: 1em;
    background-color: transparent;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.option td span.inner {
    background-color: var(--std-bgr-color);
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.option td.no-options {
    font-size: 10pt;
    font-style: italic;
    opacity: 0.8;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.sub-option {
    break-before: avoid-page;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tbody tr.sub-option td {
    font-size: 9pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tfoot.conclusion {
    display: table-row-group;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tfoot.conclusion tr.correction-sum td {
    background-color: transparent;
    padding-left: 0;
    font-size: 14pt;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tfoot.conclusion tr.correction-sum td.correction-sum-value {
    border-top-color: var(--std-text-color);
    border-top-width: 1px;
  }
  body main div#window section.questionnaire-container form#questionnaire section#reporting-container table#reporting-table tfoot.conclusion tr.correction-sum td.correction-sum-value::after {
    top: 1px;
    height: 1px;
    background-color: var(--std-text-color);
  }
}
@media (max-width: 700px) {
  :root, *::before, *::after {
    --header-height: clamp(60px, 10vh, 150px);
    --nav-height: 60px;
    --bf-info-height: 38px;
    --bf-info-main-height: 24px;
    --page-padding: .5rem;
  }
  h1 {
    font-size: 1.5em;
  }
  section.basic-info-container {
    grid-template-columns: 4fr 3fr 1fr;
    grid-template-rows: auto 3fr 3fr 1fr auto auto auto auto;
    grid-template-areas: "bflegend bflegend bflegend" "input1 input1 input1" "input2 input3 input3" "submit submit submit" "infohl infohl infohl" "info info info";
  }
  section.basic-info-container #basic-info fieldset legend {
    background-position: 50% 80%;
  }
  section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.objectname {
    padding-bottom: 0;
    padding-top: calc(2 * var(--cell-vert-padding));
  }
  section.basic-info-container #basic-info-display .info div span.label {
    font-size: 0;
  }
  section.menu menu li {
    font-size: 80%;
    padding-left: 0.5ch;
  }
  section.menu menu li::after {
    width: 0.5ch;
  }
  fieldset.page {
    margin-top: 2px;
  }
  fieldset.page .question-container {
    padding-top: 3px;
  }
  fieldset.page .question-container .question {
    --additional-spacing: 2px;
  }
  fieldset.page .question-container .question header {
    padding: calc(var(--page-padding) / 4);
    padding-left: 1.5ch;
  }
  fieldset.page .question-container .question header h4.question-title {
    margin-bottom: 0.1em;
  }
  fieldset.page .question-container .question header .explanation {
    font-size: 75%;
  }
  fieldset.page .question-container .question div.option.sub-values,
  fieldset.page .question-container .question dl.options {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
  }
  fieldset.page .question-container .question dl.options {
    gap: 0.5em 0;
  }
  fieldset.page .question-container .question dl.options dt label span.clarification {
    font-size: 80%;
  }
  #reporting-container {
    width: 100%;
    padding: calc(1 * var(--window-padding));
  }
  #reporting-container table#reporting-table tr.summary-sqm,
  #reporting-container table#reporting-table tr.summary-area,
  #reporting-container table#reporting-table tr.span-area,
  #reporting-container table#reporting-table tr.span-sqm {
    font-size: 80%;
  }
}
@media (max-width: 450px) {
  :root, *::before, *::after {
    --header-height: clamp(60px, 10vh, 150px);
    --page-padding: 3px;
  }
  html {
    font-size: 0.875em;
  }
  h1 {
    font-size: 1.5em;
  }
  main.basic-info-emphasized {
    --bf-info-height: 40px;
  }
  section.basic-info-container {
    --lable-font-size: 1.2em;
    --cell-hor-padding: calc(var(--baseunit) / 2);
  }
  section.basic-info-container #basic-info fieldset legend {
    background-position: 50% 20%;
  }
  section.basic-info-container #basic-info fieldset .input-group-container .formelement-group.objectname {
    padding-bottom: 0;
    padding-top: calc(2 * var(--cell-vert-padding));
    border-top: 1px solid var(--structuring-color);
  }
}
@media (max-width: 380px) {
  :root, *::before, *::after {
    --nav-height: 45px;
  }
  section.menu menu li {
    padding-top: 0;
    padding-bottom: 0;
  }
  section.menu menu li a {
    line-height: 1;
  }
}
@media (max-height: 600px) {
  :root, *::before, *::after {
    --header-height: clamp(60px, 5vh, 150px);
    --footer-menu-height: 2em;
    --nav-height: 45px;
    --bf-info-height: 38px;
    --bf-info-main-height: 24px;
  }
  main {
    overflow: auto;
  }
  main > div#window {
    padding-top: 0;
  }
  section.menu {
    --top-bottom-padding: 2px;
  }
  fieldset.page {
    margin-top: 2px;
  }
  fieldset.page .question-container {
    padding-top: 3px;
  }
  fieldset.page .question-container .question header {
    position: static;
    padding: calc(var(--page-padding) / 4);
  }
  fieldset.page .question-container .question header h4.question-title {
    font-size: 1em;
    line-height: 1.2;
    margin-bottom: 0.1em;
  }
  fieldset.page .question-container .question header .explanation {
    font-size: 75%;
  }
  fieldset.page .question-container .question div.option.sub-values,
  fieldset.page .question-container .question dl.options {
    margin-top: 0.5em;
    margin-bottom: 0.5em;
  }
  fieldset.page .question-container .question dl.options {
    gap: 0.5em 0;
  }
}
@media (max-height: 600px) and (hover: none) {
  section.navigation nav menu li button#restart-button, section.navigation nav menu li button#reset-button {
    align-items: center;
    padding-bottom: 0;
  }
  section.navigation nav menu li button#restart-button::before, section.navigation nav menu li button#reset-button::before {
    display: none;
  }
}