@layer layout {
  /* Selects all elements that have a direct sibling preceding them (for content flow). Added to parent element to ensure spacing between all elements. */
  .flow > * + * {
    margin-block-start: var(--flow-space, 1em);
  }

  .grid-flow {
    display: grid;
    gap: var(--grid-flow-space, 1rem);

    align-content: start;
    justify-items: start;
  }

  .wrapper {
    --wrapper-max-width: 1130px !important;
    --wrapper-padding: 1rem;

    max-width: var(--wrapper-max-width);
    margin-inline: auto;
    padding-inline: var(--wrapper-padding);

    /* helps to match the Figma file */
    box-sizing: content-box !important;
  }

  .wrapper[data-width="narrow"] {
    --wrapper-max-width: 720px !important;
  }

  .wrapper[data-width="wide"] {
    --wrapper-max-width: 1330px !important;
  }

  .section {
    padding-block: 3.75rem !important;

    @media (min-width: 760px) {
      padding-block: 8rem;

      &[data-padding="compact"] {
        padding-block: 4.5rem !important;
      }
    }

    .grid-auto-fill {
      display: grid;
      gap: 1rem;
      /* 
      * auto-fit or auto-fill. auto-fill is used to ensure that the grid columns are 
      * always filled with the minimum column size. The min() function with 100% as 
      * the second argument prevents overflow. The var allows for adjusting the 
      * minimum column size as needed. 
      */
      grid-template-columns: repeat(auto-fill, minmax(min(var(--grid-auto-fill-min-column-size, 250px), 100%), 1fr));
    }
  }

  .equal-columns {
    display: grid;
    gap: var(--equal-columns-gap, 1rem);
    align-items: var(--column-layout-alignment, start);

    &[data-gap="large"] {
      --equal-columns-gap: 2rem;
    }

    &[data-vertical-alignment="centered"] {
      --column-layout-alignment: center;
    }

    &[data-vertical-alignment="bottom"] {
      --column-layout-alignment: end;
    }

    @media (width > 760px) {
      grid-auto-flow: column;
      grid-auto-columns: 1fr;
    }
  }
}

@layer components {
  /* Hero */
  .hero {
    text-align: center;
    background-size: cover;
    font-size: var(--font-size-md);
    color: var(--text-high-contrast);
  }

  .hero__title {
    font-size: var(--font-size-heading-lg) !important;

    > span {
      display: block;
    }
  }

  /* Mushroom Guide Class is not registered in a framework group - use classic CSS class in Gutenberg editor */
  .mushroom-guide {
    /* Define custom properties scoped to the Mushroom Guide section*/
    --card-title-font-size: var(--font-size-lg);
    --card-title-color: var(--text-high-contrast);

    --card-gap: 0.75rem;
  }

  .faq-bento-grid {
    --card-title-color: var(--text-high-contrast);

    display: grid;
    gap: 1rem;
    grid-template-areas:
      "card-one"
      "card-two"
      "card-three"
      "card-four";

    .card:nth-child(1) {
      grid-area: card-one;
    }
    .card:nth-child(2) {
      grid-area: card-two;
    }
    .card:nth-child(3) {
      grid-area: card-three;
    }
    .card:nth-child(4) {
      grid-area: card-four;
    }

    .card > img {
      height: 100%;
      object-fit: cover;
    }

    @media (width > 600px) {
      grid-template-columns: 1fr 1fr;
      grid-template-areas:
        "card-one card-two"
        "card-three card-four";

      .card:nth-child(even) img {
        order: 3;
      }
    }

    @media (width > 900px) {
      grid-template-columns: 1fr 1fr 1fr;

      grid-template-areas:
        "card-one card-two card-four"
        "card-three card-three card-four";

      .card:nth-child(3) {
        display: grid;
        grid-template-columns: 300px 1fr;

        img {
          grid-column: 1;
          grid-row: 1 / 3;
        }
      }
    }
  }

  /* Card Flex Layout */
  .card {
    /* Flexbox is preferred over grid for more flexible placement of the child elements */
    display: flex;
    flex-direction: column;
    /* Use the custom property if it exists, otherwise use the fallback */
    gap: var(--card-gap, 1rem);
    padding: 1rem;
    background-color: var(--background-light);
    border-radius: var(--border-radius-3);

    img {
      border-radius: var(--border-radius-2);
    }
  }

  .card__title {
    /* Use the custom property if it exists, otherwise use the fallback */
    font-size: var(--card-title-font-size, var(--font-size-heading-sm)) !important;

    color: var(--card-title-color, var(--text-brand)) !important;
  }

  .card__note {
    margin-top: auto !important;
    background-color: var(--background-extra-light);
    padding: 0.75rem !important;
    border-radius: var(--border-radius-2);
  }

  /* Button */
  .button {
    display: inline flex;
    cursor: pointer;
    font-family: var(--ff-heading);
    font-weight: 700 !important;
    font-size: var(--font-size-md) !important;
    background-color: var(--background-accent-main) !important;
    padding: 0.5rem 1rem !important;
    border-radius: var(--border-radius-1);
  }

  .button:hover,
  .button:focus-visible {
    background: var(--background-accent-light) !important;
    color: var(--text-high-contrast);
  }

  select {
    font-family: var(--ff-heading);
    background-color: var(--background-accent-main) !important;
    color: var(--text-high-contrast) !important;
    padding: 0.5rem 0.5rem 0.5rem 1rem !important;
    border: 0;
    border-radius: var(--border-radius-2) !important;

    /* reset theme overrides */
    width: initial !important;
    height: initial !important;
  }

  .tag-list {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;

    > li {
      font-family: var(--ff-heading);
      font-size: var(--font-size-sm);
      color: var(--text-high-contrast);
      padding: 0 0.5rem;
      background-color: var(--tag-background);
      border-radius: var(--border-radius-1);

      &[data-edible="edible"] {
        --tag-background: var(--background-accent-main);
      }
      &[data-edible="toxic"] {
        --tag-background: var(--wp--preset--color--red-500);
      }

      &[data-season="summer"] {
        --tag-background: var(--background-accent-main);
      }
      &[data-season="fall"] {
        --tag-background: var(--wp--preset--color--orange-500);
      }
      &[data-season="spring"] {
        --tag-background: var(--wp--preset--color--teal-500);
      }
  }
}

@layer utilities {
  .text-center {
    text-align: center;
  }
  .text-brand {
    color: var(--text-brand);
  }
  .text-high-contrast {
    color: var(--text-high-contrast);
  }

  .section-title {
    font-size: var(--font-size-heading-regular) !important;
  }

  .background-base {
    background-color: var(--background-base);
  }
  .background-light {
    background-color: var(--background-light);
  }
  .background-extra-light {
    background-color: var(--background-extra-light);
  }
  .background-dark {
    background-color: var(--background-dark);
  }
  .background-extra-dark {
    background-color: var(--background-extra-dark);
  }

  .background-accent {
    background-color: var(--background-accent-dark);
  }

  .font-size-heading-sm {
    font-size: var(--font-size-heading-sm);
  }
  .font-size-heading-regular {
    font-size: var(--font-size-heading-regular);
  }
  .font-size-heading-lg {
    font-size: var(--font-size-heading-lg);
  }
  .font-size-heading-xl {
    font-size: var(--font-size-heading-xl);
  }

  .font-size-sm {
    font-size: var(--font-size-sm);
  }
  .font-size-regular {
    font-size: var(--font-size-regular);
  }
  .font-size-md {
    font-size: var(--font-size-md);
  }
  .font-size-lg {
    font-size: var(--font-size-lg) !important;
  }

  .visually-hidden {
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    overflow: hidden;
    position: absolute;
    white-space: nowrap;
    width: 1px;
  }
}