/* Functions & Mixins */
/* ==== Containers & Responsive Mixins ==== */
/* Defines convenience mixins for common breakpoint targets.
these are small, medium, mediumlarge, and large. These variables should be defined prior to use.
*/
/* Universal breakpoints */
.library {
  color: #3b3c43;
  overflow-x: hidden;
  background-color: #f7f7f7;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 1.5rem 0; }
  @media screen and (min-width: 48rem) {
    .library {
      margin: 2rem 0; } }
  @media screen and (min-width: 80rem) {
    .library {
      margin: 3rem 0; } }
  .library * {
    -webkit-box-sizing: border-box;
            box-sizing: border-box; }
  .library__container {
    margin: 0 auto;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
    width: 1440px;
    max-width: 100%;
    max-width: 100%;
    padding-top: 2rem;
    padding-bottom: 2rem; }
    @media (min-width: 48.0625rem) {
      .library__container {
        padding: 1.25rem 5rem; } }
    @media (max-width: 48rem) {
      .library__container {
        padding: 1.25rem 1.25rem; } }
    @media screen and (min-width: 48rem) {
      .library__container {
        padding-top: 5rem;
        padding-bottom: 5rem; } }
    @media screen and (min-width: 80rem) {
      .library__container {
        display: grid;
        grid-template-columns: minmax(0, 300px) minmax(0, auto);
        -webkit-column-gap: 1.5rem;
           -moz-column-gap: 1.5rem;
                column-gap: 1.5rem; } }
  .library__heading {
    font-size: 28px;
    font-size: 1.75rem;
    margin: 1.25rem 0 2rem;
    color: #3b3c43;
    font-weight: normal;
    text-align: start;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
    position: relative;
    z-index: 0; }
    @media screen and (min-width: 23.125rem) {
      .library__heading {
        font-size: 32px;
        font-size: 2rem; } }
    @media screen and (min-width: 48rem) {
      .library__heading {
        font-size: 36px;
        font-size: 2.25rem;
        margin: 0 0 2rem; } }
    @media screen and (min-width: 64rem) {
      .library__heading {
        font-size: 40px;
        font-size: 2.5rem;
        margin: 0 0 3rem; } }
    @media (max-width: 1025px) and (orientation: landscape) {
      .library__heading {
        margin-bottom: 2rem; } }
    @media (max-width: 1025px) and (orientation: portrait) {
      .library__heading {
        margin-bottom: 2rem; } }
    @media screen and (min-width: 80rem) {
      .library__heading {
        font-size: 46px;
        font-size: 2.875rem; } }
    .library__heading-light {
      font-weight: 400; }
  .library__category-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column; }
  @media screen and (min-width: 30rem) {
    .library__category-box {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1.5rem; } }
  @media screen and (min-width: 64rem) {
    .library__category-box {
      grid-template-columns: repeat(3, 1fr);
      -webkit-column-gap: 2rem;
         -moz-column-gap: 2rem;
              column-gap: 2rem; } }
  .library__card {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0;
    -webkit-transition: margin 300ms ease;
    transition: margin 300ms ease; }
    @media screen and (min-width: 30rem) {
      .library__card {
        padding-top: 2.1875rem; }
        .library__card.-badge {
          padding-top: 0; }
        .library__card.-inRowWithoutBadge {
          margin-top: -2.1875rem; } }
    @media screen and (min-width: 0rem) and (max-width: 29.9375rem) {
      .library__card + .library__card {
        margin-top: 1.25rem; } }
    .library__card-image {
      max-width: 10.5rem;
      margin: 0 auto;
      padding-bottom: 63%; }
      @supports (aspect-ratio: 84/53) {
        .library__card-image {
          padding-bottom: 0;
          aspect-ratio: 84 / 53; } }
      @supports (-webkit-touch-callout: none) {
        .library__card-image {
          padding-bottom: 0; } }
    .library__card-contents {
      background-color: #fff;
      -webkit-box-flex: 1;
          -ms-flex: 1;
              flex: 1;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      padding: 1rem;
      text-align: center; }
      @media screen and (min-width: 48rem) {
        .library__card-contents {
          padding: 1rem 2rem; } }
    .library__card-badge {
      background-color: #34657f;
      padding: 0.5rem 1rem 0.25rem;
      display: -webkit-inline-box;
      display: -ms-inline-flexbox;
      display: inline-flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -ms-flex-item-align: start;
          align-self: flex-start;
      font-size: 23px;
      font-size: 1.4375rem;
      line-height: 1;
      font-weight: 700;
      text-transform: uppercase;
      color: #fff; }
    .library__card-heading {
      font-size: 16px;
      font-size: 1rem;
      margin: 1rem auto;
      text-transform: uppercase;
      color: #3b3c43; }
    .library__card-text {
      font-size: 14px;
      font-size: 0.875rem;
      margin: 0; }
    .library__card-button-container {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
    .library__card-button {
      width: 100%; }
    .library__card.-hidden {
      display: none; }
  .library__buttons-container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center; }
  .library__button-load, .library__card-button {
    border: 0;
    padding: 0.9375rem 1.5625rem;
    background-color: #fbc600;
    color: #3b3c43;
    font-weight: bold;
    text-transform: uppercase;
    text-decoration: none;
    border: none;
    cursor: pointer;
    -webkit-transition: background-color 150ms ease-in-out, color 150ms ease-in-out;
    transition: background-color 150ms ease-in-out, color 150ms ease-in-out;
    line-height: 1.1;
    padding-left: 1rem;
    padding-right: 1rem;
    text-align: center; }
    .library__button-load:hover, .library__card-button:hover {
      background-color: #3b3c43;
      color: #ffffff; }
    .library__button-load:focus, .library__button-load:focus-visible, .library__card-button:focus, .library__card-button:focus-visible {
      outline-color: #3b3c43; }
    .library__button-load.-disabled, .library__card-button.-disabled {
      cursor: not-allowed; }
      .library__button-load.-disabled:hover, .library__card-button.-disabled:hover {
        background-color: #fbc600;
        color: #3b3c43; }
      .library__button-load.-disabled:focus, .library__button-load.-disabled:focus-visible, .library__card-button.-disabled:focus, .library__card-button.-disabled:focus-visible {
        outline: none; }
  .library__button-load {
    margin: 3rem auto 2rem; }
    .library__button-load.-hidden {
      display: none; }
  .library__category {
    margin: auto 1rem 2rem; }
    @media screen and (min-width: 43.75rem) {
      .library__category {
        margin: auto 2rem 2rem; } }
  .library__category-text {
    color: #FF00EB;
    font-weight: bold;
    text-transform: uppercase; }