body {
  overflow-x: hidden;
  font-family: "Montserrat", sans-serif;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  height: 100%;
}

main {
  flex-grow: 1;
}

/* .form-left border-right moved to media query below */

@media (max-width: 1080px) {
  html {
    font-size: 14px;
  }
}
/* .form-left border-bottom moved to media query below */
@media (max-width: 1080px) {
  html {
    font-size: 14px;
  }
}
@media (max-width: 420px) {
  html {
    font-size: 12px;
  }
}

.material-icons.md-18 {
  font-size: 1.125rem;
  line-height: 1.1255rem;
}

.material-icons.md-24 {
  font-size: 1.5rem;
  line-height: 1.5rem;
}

.material-icons.md-36 {
  font-size: 2.25rem;
  line-height: 2.25rem;
}

.material-icons.md-48 {
  font-size: 3rem;
  line-height: 3rem;
}

p {
  margin-bottom: 0;
}

a {
  display: block;
  color: var(--color-primary);
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0 !important;
}

legend,
h3:not(.label-like) {
  color: var(--color-primary);
  font-size: var(--font-size-l);
  padding: var(--vertical-padding) 0;
  margin: 0;
  gap: var(--vertical-padding-sm);
  display: flex;
  align-items: center;
}

h2:not(.label-like) {
  color: var(--color-primary);
  font-size: var(--font-size-l);
}

.form-right h2 {
  font-weight: var(--font-weight-bold);
}

.form-left h2 {
  color: var(--color-text-dark);
}

.btn,
.btn-light,
.btn-dark {
  display: flex;
  align-items: center;
  border-radius: 0.5em;
  padding: 0.5rem 1.5rem;
  font-size: var(--font-size-s);
}
.btn *,
.btn-light *,
.btn-dark * {
  color: inherit;
  text-decoration: inherit;
}

.btn-light,
.btn-dark:hover:not(:disabled),
.btn-dark:focus:not(:disabled) {
  color: var(--color-accent);
  background-color: transparent;
  border: var(--border-width) solid var(--color-accent);
  text-decoration: none;
  outline: none;
}

.btn-dark,
.btn-light:hover:not(:disabled),
.btn-light:focus:not(:disabled) {
  background-color: var(--color-accent);
  color: var(--color-text-light);
  border: var(--border-width) solid var(--color-accent);
  text-decoration: none;
  outline: none;
}

button:disabled {
  text-decoration: line-through !important;
  cursor: default !important;
}

i {
  color: var(--color-accent);
  vertical-align: bottom;
  pointer-events: none;
}

#buttons-container {
  display: flex;
}

header {
  display: flex;
  padding: var(--vertical-padding) var(--horizontal-padding);
  align-items: center;
  justify-content: space-between;
  min-height: 100px;
  border-bottom: var(--border-width) solid var(--color-border);
  flex-wrap: wrap;
  gap: var(--vertical-padding) var(--horizontal-padding);
}

header h1 {
  color: var(--color-primary);
  font-size: var(--font-size-xl);
  margin: 0;
}

#header-actions {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: var(--vertical-padding) 0;
}
#header-actions > div {
  display: grid;
  justify-content: center;
  align-items: center;
  padding: 0 var(--horizontal-padding);
}
#header-actions > div:first-of-type {
  padding-left: 0;
}
#header-actions > div:not(:last-child):not(:nth-last-child(2)) {
  border-width: 0;
  border-right: 1px solid;
  border-image: linear-gradient(
      transparent 0%,
      25%,
      var(--color-border) 25%,
      75%,
      transparent 75%
    )
    1;
}

footer {
  display: flex;
  flex-direction: column;
  background-color: var(--color-border);
}
footer .footerLogos,
footer nav {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
footer .footerLogos div,
footer nav div {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
}
footer a,
footer h6 {
  color: black;
  padding: var(--vertical-padding) var(--horizontal-padding);
}

@media (max-width: 420px) {
  footer .footerLogos,
  footer nav {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  footer .footerLogos div,
  footer nav div {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}

.body-content {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: var(--vertical-padding) var(--horizontal-padding);
}

.body-item {
  padding: 0 0;
  max-width: min(56rem, 80vw);
}

.body-item-row {
  display: flex;
  flex-direction: row;
  gap: var(--vertical-padding) var(--horizontal-padding);
  padding: 0;
  padding-bottom: var(--vertical-padding);
  justify-content: center;
}

.index-button {
  background: var(--color-primary-background);
  color: var(--color-primary);
  border: var(--border-width) solid var(--color-primary);
  text-align: center;
  flex-grow: 1;
  max-width: min(40ch, 50vw);
}

@media (min-width: 1080px) {
  .index-button > div {
    padding: 6rem 4rem;
  }
  .index-button > div > div {
    font-size: var(--font-size-l);
  }
}

@media (max-width: 1080px) {
  .index-button > div {
    padding: 3rem 2rem;
  }
  .index-button > div > div {
    font-size: var(--font-size-m);
  }
}

.index-button:hover,
.indexbutton:hover > div {
  background-color: var(--color-light-blue);
  text-decoration: none;
}

.index-header {
  padding-top: 0;
  padding-bottom: var(--vertical-padding);
}

.cursor-pointer {
  cursor: pointer;
  user-select: none;
}

@media (min-width: 1080px) {
  .form-content-grid {
    display: grid;
    grid-template-columns: 20% 80%;
  }
  .form-left {
    border-right: var(--border-width) solid var(--color-border);
  }
}

@media (max-width: 1080px) {
  .form-content-grid {
    display: grid;
    grid-template-columns: 100%;
  }
  .form-left {
    border-bottom: 1px solid var(--color-border);
  }
}

.form-header {
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  border-bottom: var(--border-width) solid var(--color-border);
  gap: var(--vertical-padding) var(--horizontal-padding);
  flex-wrap: wrap;
}

.buttons-wrapper {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: var(--vertical-padding) var(--horizontal-padding);
}

.form-left {
  background-color: var(--color-secondary-background);
  padding: var(--vertical-padding) var(--horizontal-padding);
}

#tableOfContents {
  position: sticky;
  top: var(--vertical-padding);
}

.form-right > * {
  padding: var(--vertical-padding) var(--horizontal-padding);
}

#actual-form {
  max-width: var(--breakpoint-tablet);
}

.required::after {
  content: attr(required-message);
  font-weight: var(--font-weight-normal);
  font-size: var(--font-size-s);
  color: var(--color-accent);
}

h4,
.label-like,
h5,
h6 {
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-s);
  margin: 0;
}

.field-validation-error {
  color: var(--color-error);
  font-size: var(--font-size-s);
  margin-top: var(--vertical-padding-sm);
}

.notification {
  color: var(--color-text-light);
  border: var(--color-text-light);
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-s);
  padding: var(--vertical-padding-sm) var(--horizontal-padding);
}
.notification.success {
  background-color: var(--color-success);
}
.notification.error {
  background-color: var(--color-error);
}
.notification > form {
  display: inline-block;
  padding: 0 var(--horizontal-padding-sm);
}

.hidden {
  visibility: hidden;
}

.hide-properties-divider {
  border-left: 4px solid;
  border-left-color: var(--color-border);
  height: auto;
  margin-bottom: var(--vertical-padding);
  padding-left: var(--horizontal-padding-sm);
}

.hide-properties-divider.multiple {
  margin-bottom: 0.5rem !important;
}

.show-hide-toggles-wrapper {
  padding: 0 var(--horizontal-padding) var(--vertical-padding)
    var(--horizontal-padding);
}

.visibility-onoff {
  color: var(--color-accent);
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 0 var(--horizontal-padding-sm);
}

.visibility-onoff:hover {
  cursor: pointer;
  user-select: none;
}

.hidden-property-element,
.hidden-property-restricted,
.toggle-admin,
.toggle-always {
  display: none;
}

.hidden-approved {
  color: var(--color-primary);
}

.hidden-rejected {
  color: var(--color-error);
}

.scroll-links {
  list-style: none;
  padding: 0;
}
.scroll-links li {
  display: flex;
  align-items: flex-start;
  margin-bottom: var(--vertical-padding-sm);
}
.scroll-links li a {
  font-size: var(--font-size-s);
}
.scroll-links li:before {
  content: "arrow_forward_ios";
  font-family: "Material Icons";
  color: var(--color-primary);
  font-size: var(--font-size-s);
}

:target {
  padding-top: var(--vertical-padding);
}

#server-notifications,
#staging-warning,
.warning-banner {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  color: var(--color-text-dark);
  background: var(--color-secondary-background);
  border-bottom: var(--border-width) solid var(--color-border);
  padding: var(--vertical-padding) var(--horizontal-padding);
}
#server-notifications i,
#staging-warning i,
.warning-banner i {
  padding-right: var(--horizontal-padding);
}
#server-notifications details p,
#staging-warning details p,
.warning-banner details p {
  padding-left: var(--horizontal-padding);
  padding-bottom: var(--vertical-padding-sm);
}

#staging-warning,
.warning-banner {
  color: var(--color-text-light);
  background: var(--color-error);

  i {
    color: var(--color-text-light);
  }
}

.green {
  color: var(--color-success) !important;
  border-color: var(--color-success) !important;
}

.green ::after {
  border-color: var(--color-success) transparent transparent transparent !important;
}

.editor-and-hiding-wrapper {
  display: grid;
  grid-template-columns: 70% 30%;
  gap: var(--vertical-padding) var(--horizontal-padding);
}

.editor-and-hiding-wrapper > div:first-of-type {
  max-width: 640px;
}

@media (min-width: 1080px) {
  .editor-and-hiding-wrapper > div:last-of-type {
    max-width: 640px;
  }
}

@media (max-width: 1080px) {
  .editor-and-hiding-wrapper {
    gap: var(--vertical-padding) var(--horizontal-padding-sm);
  }

  .editor-and-hiding-wrapper > div:last-of-type {
    padding: 0 var(--horizontal-padding-sm);
  }
}

.info-button-column {
  display: flex;
  flex-direction: column;
  gap: var(--vertical-padding-sm);
  padding-bottom: var(--vertical-padding);
}

.info-button-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--vertical-padding-sm) var(--horizontal-padding-sm);
}

.info-button-row * {
  font-size: var(--font-size-s);
}

.text-sm {
  font-size: var(--font-size-s);
}

.full-span {
  grid-column: 1/-1;
}

.icons-wrapper {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.copying-warning {
  color: var(--color-error);
  padding-bottom: var(--vertical-padding);
}

.label-wrapper {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.label-wrapper label,
.label-wrapper h4,
.label-wrapper .label-like {
  margin-right: var(--horizontal-padding-sm);
}

.languageSwitch {
  background: none;
  border: none;
  color: var(--color-primary);
}

.languageSwitch:hover {
  text-decoration: underline !important;
}

.document-wrapper {
  width: 100%;
  padding: 0 var(--horizontal-padding) var(--vertical-padding);
}
.document-wrapper h2 {
  padding-top: var(--vertical-padding);
}
.document-wrapper section {
  max-width: 80ch;
}
.document-wrapper p {
  white-space: pre-line;
}

.header-with-subtitle {
  padding: var(--vertical-padding) 0;
}
.header-with-subtitle h3,
.header-with-subtitle h2 {
  padding: 0;
}
.header-with-subtitle span {
  color: gray;
  font-size: var(--font-size-s);
}

.font-size-lg {
  font-size: 1.5rem !important;
}

.font-size-md {
  font-size: 1rem !important;
}

.ws-preline {
  white-space: pre-line !important;
}

.w-10ch {
  min-width: 10ch !important;
  width: 10ch !important;
  max-width: 10ch !important;
}

.w-20ch {
  min-width: 20ch !important;
  width: 20ch !important;
  max-width: 20ch !important;
}

.w-80ch {
  min-width: 80ch;
  width: 80ch;
}

.w-120ch {
  min-width: 120ch;
  width: 120ch;
}

.draft-notification {
  background: var(--color-accent);
  position: sticky;
  top: 0;
  z-index: 1052;
}

#loading-modal {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 320px;
  height: 320px;

  border: 2px solid var(--color-accent);
  background: white;

  color: var(--color-accent);

  display: grid;
  place-items: center;

  z-index: 5000;
}

#loading-modal-background {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 4999;
}

.validation-summary-errors {
  * {
    color: var(--color-error);
    font-size: var(--font-size-s);
  }

  ul {
    margin: 0;
    padding: var(--vertical-padding-sm) var(--horizontal-padding-sm);
    padding-left: 1.5rem;
    padding-bottom: var(--vertical-padding);
  }
}

.c-error {
  color: var(--color-error);
}

.c-dark {
  color: var(--color-text-dark) !important;
}

.p-sm {
  padding: var(--vertical-padding-sm) var(--horizontal-padding-sm);
}

.pt-sm {
  padding-top: var(--vertical-padding-sm);
}

.pb-sm {
  padding-bottom: var(--vertical-padding-sm) !important;
}

.pr-sm {
  padding-right: var(--horizontal-padding-sm);
}

.pl-sm {
  padding-left: var(--horizontal-padding-sm);
}

.px-md {
  padding-left: var(--horizontal-padding) !important;
  padding-right: var(--horizontal-padding) !important;
}

.py-md {
  padding-top: var(--horizontal-padding) !important;
  padding-bottom: var(--horizontal-padding) !important;
}

.p-md {
  padding: var(--vertical-padding) var(--horizontal-padding);
}

.pt-md {
  padding-top: var(--vertical-padding);
}

.pb-md {
  padding-bottom: var(--vertical-padding);
}

.pr-md {
  padding-right: var(--horizontal-padding);
}

.pl-md {
  padding-left: var(--horizontal-padding);
}

.px-md {
  padding-left: var(--horizontal-padding);
  padding-right: var(--horizontal-padding);
}

.px-sm {
  padding-left: var(--horizontal-padding-sm);
  padding-right: var(--horizontal-padding-sm);
}

.py-md {
  padding-top: var(--horizontal-padding);
  padding-bottom: var(--horizontal-padding);
}

.py-sm {
  padding-top: var(--horizontal-padding-sm);
  padding-bottom: var(--horizontal-padding-sm);
}

.pl-0 {
  padding-left: 0 !important;
}

.gy-sm {
  row-gap: var(--vertical-padding-sm);
}

.gx-sm {
  column-gap: var(--vertical-padding-sm);
}

.g-sm {
  gap: var(--vertical-padding-sm) var(--horizontal-padding-sm);
}

.g-md {
  gap: var(--vertical-padding) var(--horizontal-padding);
}

.two-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.bold {
  font-weight: 600;
}

.d-inline {
  display: inline !important;
}

.w-fit-content {
  width: fit-content;
}

.ellipsis {
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap;
}

.centered-row {
  display: flex;
  flex-direction: row;
  align-items: center;
}

.grid {
  display: grid;
}

.mw-80ch {
  max-width: 80ch;
}

.mh-100 {
  max-height: 100% !important;
}

.historyTable th,
.historyTable td {
  padding: var(--vertical-padding-sm) var(--horizontal-padding-sm) !important;
  vertical-align: top;
  width: 20ch;
}

dd {
  white-space: pre-line;
}

.transparent-button,
#hide-filter-button,
#show-filter-button {
    color: var(--color-accent);
    border: none;
    background-color: transparent;
}

.transparent-button {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--horizontal-padding-sm);
}

@media (max-width: 420px) {
    .transparent-button {
        flex-wrap: wrap;
    }
}