.two_columns {
  box-sizing: border-box;

  .two_columns_struct_66_33,
  .two_columns_struct_33_66 {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 40px;
    /* max-width: 2040px; */
    min-height: 657px;
    position: relative;
    width: 100%;

    .col-left {
      aspect-ratio: 1/1;
      position: absolute;
      top: 0;
      bottom: 0;
      width: 50%;

      .two_columns_img {
        width: 100%;
        height: 100%;

        .two_columns-principal-img {
          height: 100%;

          img {
            width: 100%;
            height: 100%;
            aspect-ratio: 1/1;
            object-fit: cover;
          }
        }

        iframe {
          width: 100%;
          height: 100%;
        }
      }
    }

    .col-right {
      display: flex;
      justify-content: flex-end;
      margin: 0 auto;
      max-width: 73.125rem;
      padding: 31px 24px;
      width: 100%;
      box-sizing: border-box;

      .two_columns_text {
        width: calc(50% - 60px);
        z-index: 1;

        .image__image {
          width: 104px;
          height: 106px;
        }

        .two_columns__title {
          margin-bottom: 35px;

          .alert-heading {
            font-size: 1.75rem;
          }
        }

        .two_columns__description {
          margin-bottom: 35px;

          p {
            margin: 0;
            font-weight: 300;
            letter-spacing: 0;
            font-size: 1.25rem;
            line-height: 1.4;
          }

          ul {
            list-style: none;
            margin: 1rem 0;
            padding: 0;

            li {
              color: var(--color-body);
              position: relative;
              margin-bottom: 1rem;
              padding-left: 40px;
              font-weight: 300;
              letter-spacing: 0.25px;
              font-size: 1.25rem;

              &::before {
                content: "";
                width: 20px;
                height: 20px;
                margin-left: -1.875rem;
                background-image: url(../../images/check-two-columns/check-red.svg);
                background-repeat: no-repeat;
                background-size: cover;
                float: left;
              }
            }
          }
        }

        .button {
          white-space: normal;

          &.btn-white-background {
            border: 2px solid var(--color-red);
            padding: 0;

            a {
              padding: 18px 30px !important;
            }
          }

          &.btn-red-background {
            /* padding: 0; */

            a {
              padding: 18px 30px !important;
            }
          }

          &.btn-transparent-link {
            padding: 0;
            color: var(--color-red);
          }
        }

        .cta_orientation_column .field__items {
          display: flex;
          align-items: center;
          gap: 16px;
        }

        .cta_orientation_row .field__items {
          display: flex;
          flex-direction: column;
          gap: 28px;

          .cta_button {
            display: block;

            .button {
              padding: 0;

              a {
                padding: 0;
              }
            }
          }
        }
      }
    }
  }

  .two_columns_struct_66_33 {
    .col-left {
      left: 0;
    }

    .two_columns_text {
      margin-left: auto;
    }
  }

  .two_columns_struct_33_66 {
    .col-left {
      right: 0;
      left: auto;
    }

    .col-right {
      justify-content: flex-start;
    }

    .two_columns_text {
      margin-left: 0;
      margin-right: auto;
    }
  }

  .box_shadow {
    width: 100%;
    max-width: 1170px;
    margin: 0 auto;
    padding-left: 24px;
    padding-right: 24px;

    .two_columns_struct_66_33,
    .two_columns_struct_33_66 {
      min-height: auto;
      display: flex;
      flex-direction: row-reverse;
      width: 100%;
      align-items: stretch;

      .col-left {
        display: flex;
        align-items: center;
        justify-content: end;
        overflow: hidden;
        /* width: 41.7%; */
        position: static;
        aspect-ratio: auto;

        .two_columns_img {
          border-radius: 0 4px 4px 0;
          padding: 50px 0;

          img {
            width: 100%;
            height: 100%;
            object-fit: cover;
            aspect-ratio: auto;
          }
        }
      }

      .col-right {
        background: var(--color-white);
        border-radius: 4px;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
        display: flex;
        flex-direction: column;
        padding: 60px 64px 50px;
        /* width: 58.3%; */
        margin: 0;

        .two_columns_text {
          display: flex;
          flex-direction: column;
          gap: 24px;
          width: auto;
          margin-left: 0;

          .two_columns__title {
            margin-bottom: 0;
          }

          .two_columns__description {
            margin-bottom: 0;
          }
        }
      }
    }

    .two_columns_struct_66_33 {
      .col-left {
        width: 41.7%;
      }

      .col-right {
        width: 58.3%;
      }
    }

    .two_columns_struct_33_66 {
      .col-left {
        width: 58.3%;
      }

      .col-right {
        width: 41.7%;
      }
    }
  }
}

@media (max-width: 1024px) {
  .two_columns {
    flex-direction: column;
    min-height: 0;
    padding: 0;

    .two_columns_struct_66_33,
    .two_columns_struct_33_66 {
      box-sizing: border-box;
      flex-direction: column;
      max-width: 100%;
      width: 100%;

      .col-left {
        position: relative;
        width: 100%;
        height: auto;
        aspect-ratio: auto;
        overflow: hidden;

        .two_columns_img {
          display: block;
          width: 100%;
          height: auto;

          .two_columns-principal-img {
            display: block;
            width: 100%;
            height: auto;

            img {
              display: block;
              width: 100%;
              max-width: 100%;
              height: auto;
              aspect-ratio: 1 / 1;
              object-fit: cover;
            }
          }
        }
      }

      .col-right {
        margin: 0;

        .two_columns_text {
          background: var(--color-white);
          border-radius: 4px;
          box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
          margin-left: 0;
          padding: 20px;
          width: 100%;

          /* h1 {
            font-size: 1.5rem;
          } */

          .two_columns__title {
            .alert-heading {
              font-size: 1.5rem;
            }
          }

          .field__items {
            flex-direction: column;
          }

          .field__item {
            width: 100%;

            .cta_button {
              display: grid;
              justify-content: normal;
            }
          }

          .two_columns__description {
            p {
              font-size: 1rem;
            }
          }
        }
      }
    }

    .box_shadow .two_columns_struct_66_33 .col-right {
      padding: 0;

      .two_columns_text {
        padding: 60px 64px 50px;
      }
    }
  }
}

@media (max-width: 1024px) {
  .two_columns {
    .box_shadow {
      width: auto;

      .two_columns_struct_66_33,
      .two_columns_struct_33_66 {
        box-sizing: border-box;
        flex-direction: column;
        max-width: 100%;
        width: 100%;

        .col-left {
          position: relative;
          width: 100%;
          height: auto;
          aspect-ratio: auto;
          overflow: hidden;

          .two_columns_img {
            display: block;
            width: 100%;
            height: auto;
            padding: 0;

            img {
              display: block;
              width: 100%;
              max-width: 100%;
              height: auto;
              aspect-ratio: auto;
              object-fit: cover;
            }
          }
        }

        .col-right {
          width: auto;

          .two_columns_text {
            background: var(--color-white);
            border-radius: 4px;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
            margin-left: 0;
            padding: 24px 16px;
            margin: 0;
            box-sizing: border-box;

            .alert-heading {
              font-size: 1.125rem;
            }

            h1 {
              font-size: 1.5rem;
            }

            .field__items {
              flex-direction: column;
              gap: 24px;
            }

            .field__item {
              width: 100%;

              .cta_button {
                display: grid;
                justify-content: center;

                .button {
                  width: fit-content;

                  &.btn-transparent-link {
                    a {
                      padding: 0;
                      width: fit-content;
                    }
                  }
                }
              }
            }

            .two_columns__description {
              ul {
                li {
                  font-size: 1rem;
                }
              }
            }
          }
        }
      }
    }
  }
}