/* ========== Container ========== */
.container {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
}

/* Fix for fixed navbar overlap on mobile for non-admin users */
body:not(.user-logged-in) main {
  padding-top: 80px;
}

@media (min-width: 1050px) {
  body:not(.user-logged-in) main {
    padding-top: 0;
  }
}

@media (min-width: 576px) {
  .container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .container {
    max-width: 1440px;
  }
}

@media (min-width: 1900) {
  .container {
    max-width: 2200px;
  }
}

/* ========== Row ========== */
.row {
  display: flex;
  flex-wrap: wrap;
  row-gap: 20px;
}

/* ========== Columns ========== */
.col,
[class^="col-"],
[class*=" col-"] {
  padding-right: 15px;
  padding-left: 15px;
  box-sizing: border-box;
}

/* Default full-width column */
.col {
  flex: 1 0 0%;
}

/* === Columns by size (1-12) === */
.row {

  /* Extra small (default) */
  .col-1 {
    flex: 0 0 8.33%;
    max-width: 8.33%;
  }

  .col-2 {
    flex: 0 0 16.66%;
    max-width: 16.66%;
  }

  .col-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .col-4 {
    flex: 0 0 33.33%;
    max-width: 33.33%;
  }

  .col-5 {
    flex: 0 0 41.66%;
    max-width: 41.66%;
  }

  .col-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .col-7 {
    flex: 0 0 58.33%;
    max-width: 58.33%;
  }

  .col-8 {
    flex: 0 0 66.66%;
    max-width: 66.66%;
  }

  .col-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .col-10 {
    flex: 0 0 83.33%;
    max-width: 83.33%;
  }

  .col-11 {
    flex: 0 0 91.66%;
    max-width: 91.66%;
  }

  .col-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  /* Responsive columns */
  @media (min-width: 576px) {
    .col-sm-1 {
      flex: 0 0 8.33%;
      max-width: 8.33%;
    }

    .col-sm-2 {
      flex: 0 0 16.66%;
      max-width: 16.66%;
    }

    .col-sm-3 {
      flex: 0 0 25%;
      max-width: 25%;
    }

    .col-sm-4 {
      flex: 0 0 33.33%;
      max-width: 33.33%;
    }

    .col-sm-5 {
      flex: 0 0 41.66%;
      max-width: 41.66%;
    }

    .col-sm-6 {
      flex: 0 0 50%;
      max-width: 50%;
    }

    .col-sm-7 {
      flex: 0 0 58.33%;
      max-width: 58.33%;
    }

    .col-sm-8 {
      flex: 0 0 66.66%;
      max-width: 66.66%;
    }

    .col-sm-9 {
      flex: 0 0 75%;
      max-width: 75%;
    }

    .col-sm-10 {
      flex: 0 0 83.33%;
      max-width: 83.33%;
    }

    .col-sm-11 {
      flex: 0 0 91.66%;
      max-width: 91.66%;
    }

    .col-sm-12 {
      flex: 0 0 100%;
      max-width: 100%;
    }
  }

  @media (min-width: 768px) {
    .col-md-1 {
      flex: 0 0 8.33%;
      max-width: 8.33%;
    }

    .col-md-2 {
      flex: 0 0 16.66%;
      max-width: 16.66%;
    }

    .col-md-3 {
      flex: 0 0 25%;
      max-width: 25%;
    }

    .col-md-4 {
      flex: 0 0 33.33%;
      max-width: 33.33%;
    }

    .col-md-5 {
      flex: 0 0 41.66%;
      max-width: 41.66%;
    }

    .col-md-6 {
      flex: 0 0 50%;
      max-width: 50%;
    }

    .col-md-7 {
      flex: 0 0 58.33%;
      max-width: 58.33%;
    }

    .col-md-8 {
      flex: 0 0 66.66%;
      max-width: 66.66%;
    }

    .col-md-9 {
      flex: 0 0 75%;
      max-width: 75%;
    }

    .col-md-10 {
      flex: 0 0 83.33%;
      max-width: 83.33%;
    }

    .col-md-11 {
      flex: 0 0 91.66%;
      max-width: 91.66%;
    }

    .col-md-12 {
      flex: 0 0 100%;
      max-width: 100%;
    }
  }

  @media (min-width: 992px) {
    .col-lg-1 {
      flex: 0 0 8.33%;
      max-width: 8.33%;
    }

    .col-lg-2 {
      flex: 0 0 16.66%;
      max-width: 16.66%;
    }

    .col-lg-3 {
      flex: 0 0 25%;
      max-width: 25%;
    }

    .col-lg-4 {
      flex: 0 0 33.33%;
      max-width: 33.33%;
    }

    .col-lg-5 {
      flex: 0 0 41.66%;
      max-width: 41.66%;
    }

    .col-lg-6 {
      flex: 0 0 50%;
      max-width: 50%;
    }

    .col-lg-7 {
      flex: 0 0 58.33%;
      max-width: 58.33%;
    }

    .col-lg-8 {
      flex: 0 0 66.66%;
      max-width: 66.66%;
    }

    .col-lg-9 {
      flex: 0 0 75%;
      max-width: 75%;
    }

    .col-lg-10 {
      flex: 0 0 83.33%;
      max-width: 83.33%;
    }

    .col-lg-11 {
      flex: 0 0 91.66%;
      max-width: 91.66%;
    }

    .col-lg-12 {
      flex: 0 0 100%;
      max-width: 100%;
    }
  }

  @media (min-width: 1200px) {
    .col-xl-1 {
      flex: 0 0 8.33%;
      max-width: 8.33%;
    }

    .col-xl-2 {
      flex: 0 0 16.66%;
      max-width: 16.66%;
    }

    .col-xl-3 {
      flex: 0 0 25%;
      max-width: 25%;
    }

    .col-xl-4 {
      flex: 0 0 33.33%;
      max-width: 33.33%;
    }

    .col-xl-5 {
      flex: 0 0 41.66%;
      max-width: 41.66%;
    }

    .col-xl-6 {
      flex: 0 0 50%;
      max-width: 50%;
    }

    .col-xl-7 {
      flex: 0 0 58.33%;
      max-width: 58.33%;
    }

    .col-xl-8 {
      flex: 0 0 66.66%;
      max-width: 66.66%;
    }

    .col-xl-9 {
      flex: 0 0 75%;
      max-width: 75%;
    }

    .col-xl-10 {
      flex: 0 0 83.33%;
      max-width: 83.33%;
    }

    .col-xl-11 {
      flex: 0 0 91.66%;
      max-width: 91.66%;
    }

    .col-xl-12 {
      flex: 0 0 100%;
      max-width: 100%;
    }
  }
}

.d-flex {
  display: flex;

  &.dir-column {
    flex-direction: column;
  }
}

/* ========== Layout Builder ========== */
.layout {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.layout__region {
  padding-left: 15px;
  padding-right: 15px;
  box-sizing: border-box;
  flex: 0 0 100%;
  /* Default to full width for mobile */
  max-width: 100%;
}

@media (min-width: 768px) {

  /* Two column layout */
  .layout--twocol-section>.layout__region {
    flex: 0 0 50%;
    max-width: 50%;
  }

  /* Three column layout */
  .layout--threecol-section>.layout__region {
    flex: 0 0 33.3333%;
    max-width: 33.3333%;
  }

  /* Four column layout */
  .layout--fourcol-section>.layout__region {
    flex: 0 0 25%;
    max-width: 25%;
  }
}

.layout-builder-block {
  padding: 0;
}