/* source-sans-3-regular - latin */
@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 400;
  src: url('../Fonts/SourceSans/source-sans-3-v19-latin-regular.woff2') format('woff2');
}

/* source-sans-3-700 - latin */
@font-face {
  font-display: swap;
  font-family: 'Source Sans 3';
  font-style: normal;
  font-weight: 700;
  src: url('../Fonts/SourceSans/source-sans-3-v19-latin-700.woff2') format('woff2');
}

:root {
  --bs-body-font-family: 'Source Sans 3', sans-serif;
  --bs-body-font-size: 1.125rem;
  --bs-body-color: var(--ihk-color-blue);
  --bs-border-color: var(--ihk-color-blue);
  --bs-border-radius: var(--ihk-border-radius-30);

  --ihk-color-white: #FFFFFF;
  --ihk-color-gray: #999999;
  --ihk-color-black: #000000;
  --ihk-color-blue: #004988;
  --ihk-color-blue-light: #E5ECF3;
  --ihk-color-green: #68B43A;
  --ihk-color-red: #D80F2B;

  --ihk-border-radius-30: 1.875rem;
  --ihk-field-gap: 0.75rem;

  @media (min-width: 768px) {
    --bs-body-font-size: 1.25rem;
  }
}

h1 {
  margin-bottom: 1em;
  color: var(--ihk-color-blue);
  font-size: 2.25rem;
  font-weight: 700;

  @media (min-width: 768px) {
    font-size: 3.5rem;
  }
}

h2 {
  margin-bottom: 0;
  color: var(--ihk-color-blue);
  font-size: 1.5rem;
  font-weight: 700;

  @media (min-width: 768px) {
    font-size: 2rem;
  }
}

.btn {
  --bs-btn-padding-x: 1.5rem;
  --bs-btn-padding-y: 0.5rem;
  --bs-btn-font-size: var(--bs-body-font-size);
  --bs-btn-font-weight: 700;

  &.btn-primary {
    --bs-btn-bg: var(--ihk-color-green);
    --bs-btn-border-color: var(--ihk-color-green);
    --bs-btn-hover-bg: var(--ihk-color-green);
    --bs-btn-hover-border-color: var(--ihk-color-green);
  }

  &.btn-outline-primary {
    --bs-btn-color: var(--ihk-color-blue);
    --bs-btn-border-color: var(--ihk-color-blue);
    --bs-btn-hover-color: var(--ihk-color-white);
    --bs-btn-hover-bg: var(--ihk-color-blue);
    --bs-btn-hover-border-color: var(--ihk-color-blue);
    --bs-btn-active-color: var(--ihk-color-white);
    --bs-btn-active-bg: var(--ihk-color-blue);
    --bs-btn-active-border-color: var(--ihk-color-blue);
  }

  &.btn-danger {
    --bs-btn-bg: var(--ihk-color-red);
    --bs-btn-border-color: var(--ihk-color-red);
    --bs-btn-hover-bg: var(--ihk-color-red);
    --bs-btn-hover-border-color: var(--ihk-color-red);
  }

  &.btn-outline-danger {
    --bs-btn-color: var(--ihk-color-red);
    --bs-btn-border-color: var(--ihk-color-red);
    --bs-btn-hover-color: var(--ihk-color-white);
    --bs-btn-hover-bg: var(--ihk-color-red);
    --bs-btn-hover-border-color: var(--ihk-color-red);
    --bs-btn-active-color: var(--ihk-color-white);
    --bs-btn-active-bg: var(--ihk-color-red);
    --bs-btn-active-border-color: var(--ihk-color-red);
  }
}

.footnote {
  font-size: 1rem;
  line-height: 1.3;
}

.form-control,
.form-select {
  background-color: var(--ihk-color-blue-light);
  font-size: var(--bs-body-font-size);
}

.form-select:disabled {
  background-color: transparent;
  border-color: var(--ihk-color-gray);
  color: var(--ihk-color-gray);
}

.form-check-input:checked {
  background-color: var(--ihk-color-blue);
  border-color: var(--ihk-color-blue);
}

.form-floating {
  & > .form-control,
  & > .form-select {
    padding-left: 1.5rem;
  }

  & > label {
    padding: 1rem 1.5rem;
    line-height: 1.2;
    color: var(--ihk-color-blue);
  }
}

.form-floating > .form-control-plaintext ~ label,
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
  transform: scale(.75) translateY(-.5rem) translateX(.5rem);
  opacity: 0.8;
}

.form-floating > textarea:focus ~ label::after,
.form-floating > textarea:not(:placeholder-shown) ~ label::after {
  background-color: transparent;
}

.pseudo-select {
  border: 1px solid var(--ihk-color-gray);
  border-radius: var(--bs-border-radius);
  padding: 0.5rem 1.5rem;
  color: var(--ihk-color-gray);
  line-height: 1;
  cursor: not-allowed;

  .footnote {
    opacity: 0.8;
  }
}

.tx-powermail {
  margin: 0 auto;
  padding: 1.5rem;
  max-width: 1320px;
  border-radius: 3.125rem;
  background-color: var(--ihk-color-blue-light);

  @media (min-width: 768px) {
    padding: 5rem;
  }

  .powermail_fieldset {
    margin: 0 calc(-1 * var(--ihk-field-gap));
    padding-bottom: 2.5rem;
    display: flex;
    flex-wrap: wrap;
    row-gap: 0.75rem;

    @media (min-width: 768px) {
      padding-bottom: 4rem;
      row-gap: 1.5rem;
    }

    &:last-of-type {
      padding-bottom: 0;
    }

    .powermail_legend {
      margin: 0 var(--ihk-field-gap) 1rem var(--ihk-field-gap);
      padding: 0.75rem 1.5rem;
      width: calc(100% + 4rem);
      border-radius: var(--ihk-border-radius-30);
      background-color: var(--ihk-color-blue);
      color: var(--ihk-color-white);
      font-size: 20px;
      font-weight: 700;

      @media (min-width: 768px) {
        margin-left: calc(-1 * (2rem - var(--ihk-field-gap)));
        margin-right: calc(-1 * (2rem - var(--ihk-field-gap)));
        padding: 1rem 2rem;
      }
    }

    .powermail_fieldwrap {
      padding: 0 var(--ihk-field-gap);
      width: 100%;

      @media (min-width: 992px) {
        &.width-33 {
          width: 33.33333%
        }

        &.width-66 {
          width: 66.66666%
        }

        &.width-50 {
          width: 50%
        }
      }
    }

    .powermail_fieldwrap_type_radio .form-check {
      margin-bottom: 0.5rem;

      @media (min-width: 768px) {
        margin-right: 2rem;
        margin-bottom: 0;
        display: inline-block;
      }
    }

    .powermail_fieldwrap_type_textarea .form-control {
      min-height: 200px;
    }

    .powermail_fieldwrap_type_file .form-control {
      padding: 1rem 1.5rem;
    }

    .powermail_fieldwrap_type_content img {
      max-width: 100%;
      height: auto;
    }

    .powermail_fieldwrap_type_submit {
      margin-top: 1rem;
      text-align: center;
    }
  }

  .powermail_confirmation .table,
  .powermail_create .table {
    --bs-table-bg: transparent;
    --bs-table-color: var(--ihk-color-blue);
  }

  .powermail_tab_navigation {
    display: flex;
    justify-content: center;
    gap: var(--ihk-field-gap);
  }
}

ul.powermail-errors-list {
  padding: 0 1.5rem;
  list-style: none;
  color: var(--ihk-color-red);
  font-size: 1rem;

  &.filled {
    margin-top: 0.5rem;
    margin-bottom: 0;
  }
}

/* custom html element for image preview */
image-input-field {
  display: block;
  border: 1px solid var(--ihk-color-blue);
  border-radius: var(--ihk-border-radius-30);
  padding: 1.5rem;
  text-align: center;

  .preview-container {
    width: 100%;
    height: 300px;
    margin-bottom: 1rem;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  img {
    max-width: 100%;
    max-height: 100%;
    border-radius: 0.5rem;
  }
}
