:root {
  --header-height: 75px;
  --footer-height: 100px;
}

*, :after, :before {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

header {
  height: var(--header-height);
  width: 100%;
  position: relative;
  background-color: var(--brand-white);

  nav {
    .header-logo {
      text-align: center;

      img {
        height: var(--header-height);
        padding: 12px;
      }
    }
  }
}

footer {
  height: var(--footer-height);
  width: 100%;
  position: relative;
  background-color: var(--brand-grey-50);

  .footer-menu {
    width: 100%;
    padding: 0 var(--public-spacing-06);
    max-width: calc(var(--common-grid-xl-max-width) - (var(--public-spacing-06) * 2));
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    ul {
      margin: 0;
      padding: 0;
      list-style: none;
      
      li {
        float: left;
        
        &:not(:last-of-type) {
            margin-right: var(--common-spacing-07);
          }

        a {
          color: var(--brand-grey-700);
          text-decoration: none;

          &:hover, &:active, &:focus {
            text-decoration: underline;
          }
        }
      }
    }
  }
}

.center {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.text-center {
  text-align: center;
}

.center-content {
  padding: var(--public-spacing-06);
  min-height: calc(100vh - (var(--header-height) + var(--footer-height)));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;

  @media (min-width: 480px) {
    padding: var(--public-spacing-10);
  }

  .card {
    width: 100%;
    max-width: 400px;
  }
}

.page-title {
  margin-bottom: var(--common-grid-lg-gutter);
}

form {
  &.disabled {
    sol-button[type="submit"] {
      pointer-events: none;
      opacity: 50%;
    }
  }
}

.form-group {
  &:not(:last-of-type) {
    margin-bottom: var(--common-spacing-07);
  }

  .form-element {
    margin-bottom: var(--common-spacing-04);
    width: 100%;
    display: block;
  }
}

.text-danger {
  color: var(--components-ds-error-message-color);
}

input {
  outline: 0;
  border-style: solid;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  width: -webkit-fill-available;
  width: fill-available;
  outline-width: 0;
  font: var(--components-ds-input-font);
  color: var(--components-ds-input-color);
  border: var(--components-ds-input-border-width) solid var(--components-ds-input-border-color);
  border-radius: var(--components-ds-input-border-radius);
  padding: var(--components-ds-input-padding);
  transition-property: color, background-color, border-color, box-shadow, display, outline, transition;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.2, 0.9, 0.4, 1);

  &:focus:not(.input-validation-error) {
    border-color: var(--components-ds-input-focus-border-color);
    box-shadow: 0 0 0 calc(var(--components-ds-input-focus-border-width) - var(--components-ds-input-border-width)) var(--components-ds-input-focus-border-color);
  }

  &.input-validation-error {
    border-color: var(--components-ds-error-message-color);

    &:focus {
      box-shadow: 0 0 0 calc(var(--components-ds-input-focus-border-width) - var(--components-ds-input-border-width)) var(--components-ds-error-message-color);
    }
  }
}

label {
  font: var(--components-ds-label-font);
  color: var(--components-ds-label-color);
  width: fit-content;
  display: flex;
  column-gap: var(--components-ds-label-gap);
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: end;
  margin-bottom: calc(var(--components-ds-label-font-bottom-crop) * -1);
}

.icon-large {
  --components-ds-icon-default-size: 80px;
}

.icon-alert {
    --components-ds-icon-color-default: var(--brand-red-500);
}