:root {
  --cliffy-pnav-logo-width: 175px;
  --cliffy-pnav-logo-height: auto;
  --cliffy-pnav-bg-color: #333;
  --cliffy-pnav-menu-item-margin: 0 0 .5rem 0;
  --cliffy-pnav-a-bg-color: transparent;
  --cliffy-pnav-a-hover-bg-color: #fff;
  --cliffy-pnav-a-bg-image: none;
  --cliffy-pnav-a-hover-bg-image: none;
  --cliffy-pnav-a-color: #fff;
  --cliffy-pnav-a-hover-color: #333;
  --cliffy-pnav-a-weight: normal;
  --cliffy-pnav-a-lh: inherit;
  --cliffy-pnav-a-padding: .5rem;
  --cliffy-pnav-a-border: 1px solid #fff;
  --cliffy-pnav-a-br: 10px;
  --pnav-a-color: #fff;
  --pnav-a-fw: normal;
  --pnav-a-hover-fw: normal;
  --pnav-a-hover-color: #000;
  --pnav-a-selected-color: #fff;
  --pnav-group-name-fw: bold;
  --pnav-group-name-top-border: #707070;
  --pnav-group-name-hover-top-border: #707070;
  --pnav-group-name-selected-top-border: #707070;
  --pnav-group-name-bottom-border: #707070;
  --pnav-group-name-hover-br: .375rem;
  --pnav-group-name-hover-bottom-border: #707070;
  --pnav-group-name-selected-bottom-border: #707070;
  --pnav-a-hover-bg-color: #fff;
  --pnav-a-hover-bg-image: none;
  --pnav-a-selected-bg-color: #707070;
  --pnav-a-selected-bg-image: none;
  --pnav-a-selected-fw: bold;
  --pnav-a-selected-br: .375rem;
  --cliffy-splitbtn-a-color: #fff;
  --cliffy-splitbtn-a-hover-color: #fff;
  --cliffy-splitbtn-a-bg-color: #707070;
  --cliffy-splitbtn-a-border-color: #707070;
  --cliffy-splitbtn-btn-color: #fff;
  --cliffy-splitbtn-btn-bg-color: #4e4e4e;
  --cliffy-splitbtn-btn-border-color: #4e4e4e;
  --cliffy-breadcrumb-a-color: #fff;
  --cliffy-breadcrumb-separator-color: #fff;
}

layout-wrapper-outer.cliffy {
  & layout-wrapper-inner {
    & > cliffy-content-wrapper {
      & content-container {
        padding-top: 1rem;
        padding-bottom: 1rem;
      }
    }
  }
}

layout-wrapper-outer.cliffy {
  & layout-wrapper-inner {
    display: flex;
    flex-direction: column;

    & > cliffy-content-wrapper {
      display: flex;
      flex-direction: column;
      flex: 1 0 auto;
      row-gap: 1rem;

      @media (width >= 992px) {
        flex-direction: row;
        row-gap: 0;
      }
    }
  }
}

layout-wrapper-outer.cliffy {
  & layout-wrapper-inner {
    & > cliffy-content-wrapper {
      & content-container {
        container-type: inline-size;
        container-name: content-container;
      }
    }
  }
}

layout-wrapper-outer.cliffy {
  & layout-wrapper-inner:has( > cliffy-content-wrapper.fixed) {
    height: 100vh;

    & > cliffy-content-wrapper.fixed {
      overflow-y: auto;
      overflow-x: auto;
      flex-grow: 1;
      position: relative;
    }
  }

  &:has( > layout-wrapper-inner > cliffy-content-wrapper.fixed) {
    & footer {
      display: none;
    }
  }
}

layout-wrapper-outer.cliffy {
  & layout-wrapper-inner {
    & > cliffy-content-wrapper {
      & content-container.narrow {
        width: 100%;

        @media (width >= 576px) {
          width: 540px;
        }
      }
    }
  }
}

.cliffy sidebar {
  display: block;
  padding: 1rem;
  background-color: #f1f3f6;
  border-radius: 10px;
  border: 1px solid #00000020;
  margin: 1rem;

  @media (width >= 992px) {
    width: 320px;
    flex-shrink: 0;
    flex-grow: 0;
  }
}

.cliffy nav-header#horizontal-nav-header {
  @media (width >= 992px) {
    display: none;
  }
}

.cliffy nav-header#vertical-nav-header {
  @media (width >= 992px) {
    display: block;
  }
}

.cliffy nav-wrapper {
  & split-button {
    display: inline-flex;

    & > a {
      display: inline-block;
      text-align: center;
      vertical-align: middle;
      cursor: pointer;
      border: 1px solid;
      color: var(--cliffy-splitbtn-a-color);
      background-color: var(--cliffy-splitbtn-a-bg-color);
      border-color: var(--cliffy-splitbtn-a-border-color);
      padding: .375rem .75rem;
      font-size: 1rem;
      border-radius: .375rem 0 0 .375rem;
      transition: background-color .15s ease-in-out, border-color .15s ease-in-out;
      white-space: nowrap;
      text-decoration: none;

      &:hover {
        color: var(--cliffy-splitbtn-a-hover-color);
      }
    }

    & div.dropdown-wrapper {
      position: relative;

      & button.dropdown-menu-toggle {
        border-radius: 0 .375rem .375rem 0;
        color: var(--cliffy-splitbtn-btn-color);
        background-color: var(--cliffy-splitbtn-btn-bg-color);
        border-color: var(--cliffy-splitbtn-btn-border-color);

        &:after {
          content: "";
          font-family: "Font Awesome 5 Free";
          font-weight: 900;
        }

        &:focus {
          box-shadow: none;
          outline: revert;
        }
      }

      & ul {
        display: none;
        background-color: #fff;
        border: 1px solid #00000026;
        border-radius: .25rem;
        padding: .5rem 0;
        text-align: left;
        list-style-type: none;
        position: absolute;
        z-index: 1000;
        left: 0;
        right: auto;
        top: 100%;
        min-width: 18rem;

        & li {
          & a {
            text-decoration: none;
            padding: .5rem 1rem;
            color: #212529;
            font-size: 1rem;
            font-weight: 500;
            display: block;

            &:hover {
              color: #1e2125;
              background-color: #e9ecef;
            }
          }
        }

        &.show {
          display: block;
        }
      }
    }
  }
}

.cliffy nav.breadcrumb {
  margin-bottom: 0;

  & ol {
    padding-left: 0;
    margin-bottom: 0;
    display: flex;
    flex-wrap: wrap;
    list-style-type: none;
    column-gap: .5rem;
    align-items: baseline;

    & li {
      & a {
        color: var(--cliffy-breadcrumb-a-color);
      }

      &.active {
        color: #212529bf;
      }

      &:last-child a {
        font-weight: bold;
        font-size: 1.2em;
        font-weight: bold;
      }
    }

    & li + li:before {
      content: "/";
      padding-right: .5rem;
      color: var(--cliffy-breadcrumb-separator-color);
    }
  }
}

.cliffy nav-wrapper {
  & content-container {
    @media (width >= 992px) {
      & > nav#primary-navigation {
        grid-area: auto;
      }

      padding-left: 0;
    }
  }
}

@media (width >= 992px) {
  layout-wrapper-outer.cliffy {
    margin-left: 250px;
  }

  .cliffy nav#primary-navigation {
    & menu-wrapper-outer {
      display: block;
      position: fixed;
      z-index: 1000;
      top: 0;
      bottom: 0;
      left: 0;

      & menu-wrapper-inner {
        display: block;
        padding: 1rem 0;
        overflow-y: auto;
        height: 100%;
        width: 250px;
        background-color: var(--cliffy-pnav-bg-color);

        & nav-header {
          text-align: center;
          margin: 1rem .5rem 2rem;

          & a {
            & img {
              width: var(--cliffy-pnav-logo-width);
              height: var(--cliffy-pnav-logo-height);
            }
          }
        }

        & ul.nav-menu {
          margin: 0 .5rem;

          & li.menu-item, & li.menu-item-dropdown {
            display: block;

            & a.menu-link, & a.dropdown-menu-toggle {
              background-color: var(--cliffy-pnav-a-bg-color);
              background-image: var(--cliffy-pnav-a-bg-image);
              padding: var(--cliffy-pnav-a-padding);
              border: var(--cliffy-pnav-a-border);
              border-radius: var(--cliffy-pnav-a-br);
              color: var(--cliffy-pnav-a-color);
              font-weight: var(--cliffy-pnav-a-weight);
              line-height: var(--cliffy-pnav-a-lh);

              &:hover {
                background-color: var(--cliffy-pnav-a-hover-bg-color);
                background-image: var(--cliffy-pnav-a-hover-bg-image);
                color: var(--cliffy-pnav-a-hover-color);
              }
            }

            &:not(:last-child) {
              margin: var(--cliffy-pnav-menu-item-margin);
            }
          }

          & li.menu-item-dropdown {
            & a.dropdown-menu-toggle {
              display: flex;
              align-items: center;
              column-gap: .5rem;

              &:after {
                margin-left: auto;
                transform: rotate(-90deg);
                display: inline-block;
              }
            }

            & ul.dropdown-menu-list {
              position: fixed;
              left: 250px;
              top: 0;
              bottom: 0;
              overflow-y: auto;
              width: 400px;
              background-color: #fff;
              box-shadow: 4px 0 15px -2px #0003;
              border: 0;
              border-radius: 0;
              padding: 0 0 1rem;

              & li.dropdown-menu-item {
                border-bottom: 1px solid #6c757d;

                &:has( > dropdown-header) {
                  display: list-item;
                }

                & dropdown-header {
                  display: flex;
                  align-items: center;
                  column-gap: .5rem;
                  padding: 1rem;
                  background-color: #ececec;
                  color: #212515;

                  & h5 {
                    margin: 0;
                    margin-right: auto;
                  }

                  & > a {
                    padding: 0;
                    color: #212529;
                    font-size: 1rem;
                    display: block;
                    text-decoration: none;
                  }
                }

                & a.dropdown-menu-link, & span {
                  padding: .75rem 1rem;
                }
              }
            }
          }
        }
      }
    }
  }
}

.cliffy nav#primary-navigation {
  & ul.nav-menu {
    padding-left: 0;
    list-style-type: none;
    margin: 0 .5rem;

    & li.menu-group {
      & a {
        color: var(--pnav-a-color);
        text-decoration: none;
        display: block;

        & small {
          display: block;
          font-weight: normal;
        }

        &.group-name {
          font-weight: var(--pnav-group-name-fw);
          margin-bottom: .5rem;
          padding: .375rem .75rem;
          border-top: 1px solid var(--pnav-group-name-top-border);
          border-bottom: 1px solid var(--pnav-group-name-bottom-border);

          &:hover {
            border-top: 1px solid var(--pnav-group-name-hover-top-border);
            border-bottom: 1px solid var(--pnav-group-name-hover-bottom-border);
            border-radius: var(--pnav-group-name-hover-br);
          }

          &.selected {
            border-top: 1px solid var(--pnav-group-name-selected-top-border);
            border-bottom: 1px solid var(--pnav-group-name-selected-bottom-border);
          }
        }

        &:hover {
          background-color: var(--pnav-a-hover-bg-color);
          background-image: var(--pnav-a-hover-bg-image);
          border-radius: .375rem;
          color: var(--pnav-a-hover-color);
        }

        &.selected {
          color: var(--pnav-a-selected-color);
          background-color: var(--pnav-a-selected-bg-color);
          background-image: var(--pnav-a-selected-bg-image);
          border-radius: var(--pnav-a-selected-br);
          font-weight: var(--pnav-a-selected-fw);

          &:hover {
            font-weight: var(--pnav-a-selected-fw);
          }
        }
      }

      & ul {
        margin: 0 0 .5rem;
        padding-left: 0;
        list-style-type: none;

        & li {
          & a {
            padding: .375rem .75rem;
            font-weight: var(--pnav-a-fw);

            &.external-link {
              display: flex;
              justify-content: space-between;
              column-gap: .5rem;
              align-items: center;
            }

            &:hover {
              font-weight: var(--pnav-a-hover-fw);
            }
          }
        }
      }

      &.extra {
        & > span {
          display: block;
          color: var(--pnav-a-color);
          font-weight: var(--pnav-group-name-fw);
          margin-bottom: .5rem;
          padding: .375rem .75rem;
          border-top: 1px solid var(--pnav-group-name-top-border);
          border-bottom: 1px solid var(--pnav-group-name-bottom-border);
        }
      }
    }
  }
}

:root {
  --bux-hb-bg-color: #b2b3d5;
  --bux-hb-padding: .5rem .75rem;
  --bux-nav-wrap-bg-color: #333;
  --bux-nav-wrap-padding: .5rem 0;
  --bux-nav-a-color: #fff;
  --bux-nav-a-hover-color: #fff;
  --bux-nav-a-border: none;
  --bux-nav-a-br: 0;
  --bux-nav-a-lh: inherit;
  --bux-nav-a-bg-color: transparent;
  --bux-nav-a-hover-bg-color: transparent;
  --bux-nav-a-bg-image: none;
  --bux-nav-a-hover-bg-image: none;
  --bux-footer-bg-color: #e4e6e7;
  --bux-footer-color: #000;
}

html, body {
  height: 100%;
}

layout-wrapper-outer {
  display: flex;
  flex-direction: column;
  min-height: 100%;

  & layout-wrapper-inner {
    flex: 1 0 auto;
  }
}

.nav-dropdown-menu-end {
  right: 0 !important;
  left: auto !important;
}

header-bar {
  display: block;
  padding: var(--bux-hb-padding);
  background-color: var(--bux-hb-bg-color);

  &.disabled {
    display: none;
  }
}

nav-wrapper {
  display: block;
  background-color: var(--bux-nav-wrap-bg-color);
  padding: var(--bux-nav-wrap-padding);

  & content-container {
    @media (width >= 992px) {
      display: grid;
      grid-template-columns: max-content auto auto;
      align-items: center;
      column-gap: 1rem;
    }

    & > nav-header {
      & a {
        & img {
          height: 30px;
          width: auto;
        }
      }

      @media (width >= 992px) {
        grid-area: 1 / 1 / 2 / 2;
      }
    }

    & nav {
      & ul.nav-menu {
        padding-left: 0;
        margin-bottom: 0;
        list-style-type: none;

        & li.menu-item, & li.menu-item-dropdown {
          & a.menu-link, & a.dropdown-menu-toggle {
            text-decoration: none;
            display: block;
            padding: .5rem 0;
            color: var(--bux-nav-a-color);
            border: var(--bux-nav-a-border);
            border-radius: var(--bux-nav-a-br);
            background-color: var(--bux-nav-a-bg-color);
            background-image: var(--bux-nav-a-bg-image);
            line-height: var(--bux-nav-a-lh);

            @media (width >= 992px) {
              padding: .375rem .75rem;
            }

            &:hover {
              background-color: var(--bux-nav-a-hover-bg-color);
              background-image: var(--bux-nav-a-hover-bg-image);
              color: var(--bux-nav-a-hover-color);
            }
          }

          & a.menu-link.external-link {
            display: flex;
            justify-content: space-between;
            column-gap: .5rem;
            align-items: center;
          }
        }

        & li.menu-item-dropdown {
          & a.dropdown-menu-toggle {
            display: flex;
            align-items: center;
            column-gap: .5rem;

            @media (width >= 992px) {
              display: block;
            }

            &:after {
              content: "";
              font-family: "Font Awesome 5 Free";
              font-weight: 900;
              font-size: 8pt;
              margin-left: auto;
            }

            @media (width >= 992px) {
              &:after {
                margin-left: .5rem;
              }
            }

            & img {
              border-radius: 25px;
              height: 20px;
              width: auto;
            }

            @media (width >= 992px) {
              & img {
                height: 25px;
                margin-right: .5rem;
              }
            }
          }

          & ul.dropdown-menu-list {
            display: none;
            background-color: #fff;
            border: 1px solid #00000026;
            border-radius: .25rem;
            padding: .5rem 0;
            text-align: left;
            list-style-type: none;

            & li.dropdown-menu-item {
              & a.dropdown-menu-link, & span {
                text-decoration: none;
                padding: .5rem 1rem;
                color: #212529;
                font-size: 1rem;
                font-weight: 500;
                display: block;

                & h6, & p {
                  margin-bottom: 0;
                }

                & p {
                  font-weight: normal;
                  font-size: 11pt;
                  margin-top: .25rem;
                }
              }

              & a.dropdown-menu-link:hover {
                color: #1e2125;
                background-color: #e9ecef;
              }

              &:has( > dropdown-header) {
                display: none;
              }
            }

            @media (width >= 992px) {
              position: absolute;
              z-index: 1000;
              left: 0;
              right: auto;
              top: 100%;
              min-width: 18rem;
            }
          }

          & ul.dropdown-menu-list.show {
            display: block;
          }

          @media (width >= 992px) {
            position: relative;
          }
        }

        & li.menu-item-dropdown#user-menu {
          & a.nav-dropdown-toggle {
            white-space: nowrap;
          }
        }

        @media (width >= 992px) {
          & li.menu-item, & li.menu-item-dropdown {
            display: inline-block;
          }
        }
      }
    }

    @media (width >= 992px) {
      & > nav#primary-navigation {
        grid-area: 1 / 2 / 2 / 3;
      }

      & > nav#secondary-navigation {
        grid-area: 1 / 3 / 2 / 4;
      }
    }
  }
}

nav#secondary-navigation {
  @media (width >= 992px) {
    margin-left: auto;
    display: flex;
    align-items: center;
  }
}

nav-header#horizontal-nav-header {
  display: block;
}

nav-header#vertical-nav-header {
  display: none;
}

nav#secondary-navigation {
  & ul.nav-menu {
    & li.menu-item#admin-tools {
      &.disabled {
        display: none;
      }
    }
  }
}

body > layout-wrapper-outer > footer {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.5rem;
  background-color: var(--bux-footer-bg-color);
  padding: 2rem;
  text-align: center;
  border-top: 1px solid #c4c7ca;

  & p#footer-copyright {
    margin-bottom: 0;
    color: var(--bux-footer-color);
  }
}

a.inline-action {
  display: inline-block;
  padding-left: .5em;
  font-size: 10pt;
}

content-container {
  display: block;
  width: 100%;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-right: auto;
  margin-left: auto;

  @media (width >= 576px) {
    max-width: 540px;
  }

  @media (width >= 768px) {
    max-width: 720px;
  }

  @media (width >= 992px) {
    max-width: 960px;
  }

  @media (width >= 1200px) {
    max-width: 1140px;
  }

  @media (width >= 1400px) {
    max-width: 1320px;
  }

  &.fluid {
    max-width: 100%;
  }
}

content-container.sm {
  max-width: 100%;

  @media (width >= 576px) {
    max-width: 540px;
  }

  @media (width >= 768px) {
    max-width: 720px;
  }

  @media (width >= 992px) {
    max-width: 960px;
  }

  @media (width >= 1200px) {
    max-width: 1140px;
  }

  @media (width >= 1400px) {
    max-width: 1320px;
  }
}

content-container.md {
  max-width: 100%;

  @media (width >= 768px) {
    max-width: 720px;
  }

  @media (width >= 992px) {
    max-width: 960px;
  }

  @media (width >= 1200px) {
    max-width: 1140px;
  }

  @media (width >= 1400px) {
    max-width: 1320px;
  }
}

content-container.lg {
  max-width: 100%;

  @media (width >= 992px) {
    max-width: 960px;
  }

  @media (width >= 1200px) {
    max-width: 1140px;
  }

  @media (width >= 1400px) {
    max-width: 1320px;
  }
}

content-container.xl {
  max-width: 100%;

  @media (width >= 1200px) {
    max-width: 1140px;
  }

  @media (width >= 1400px) {
    max-width: 1320px;
  }
}

content-container.xxl {
  max-width: 100%;

  @media (width >= 1400px) {
    max-width: 1320px;
  }
}

layout-wrapper-inner > content-container {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

layout-wrapper-inner > content-container {
  container-type: inline-size;
  container-name: content-container;
}

layout-wrapper-outer {
  & layout-wrapper-inner:has( > bux-content-wrapper.fixed) {
    display: flex;
    flex-direction: column;
    height: 100vh;

    & > bux-content-wrapper.fixed {
      overflow-y: auto;
      overflow-x: auto;
      flex-grow: 1;
      position: relative;
    }
  }

  &:has( > layout-wrapper-inner > bux-content-wrapper.fixed) {
    & footer {
      display: none;
    }
  }
}

layout-wrapper-outer {
  & layout-wrapper-inner {
    & content-container.narrow {
      width: 100%;

      @media (width >= 576px) {
        width: 540px;
      }
    }
  }
}

#bux-document-exception:not(:empty) {
  display: block;
  position: fixed;
  bottom: 1em;
  left: 1em;
  right: 1em;
  background-color: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
  padding: 1rem;
  text-align: center;
  z-index: 100000;
  box-shadow: 0 0 2em #000;
  border-radius: 1em;
}

#bux-document-exception {
  display: none;
}

contact {
  & name {
    display: block;
    font-size: 1rem;
    font-weight: 500;
  }

  & title {
    display: block;
    font-size: .9rem;
  }

  & company {
    display: block;
    font-size: .9rem;
  }
}

*, :before, :after {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica Neue, Noto Sans, Liberation Sans, Arial, sans-serif, Apple Color Emoji, Segoe UI Emoji, Segoe UI Symbol, Noto Color Emoji;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
}

hr {
  margin: 1rem 0;
  color: inherit;
  border: 0;
  border-top: 1px solid #212529;
  opacity: .25;
}

h1, h2, h3, h4, h5, h6 {
  margin-top: 0;
  margin-bottom: .5rem;
  font-weight: 500;
  line-height: 1.2;
  color: inherit;
}

h1 {
  font-size: calc(1.375rem + 1.5vw);

  @media (width >= 1200px) {
    font-size: 2.5rem;
  }
}

h2 {
  font-size: calc(1.325rem + .9vw);

  @media (width >= 1200px) {
    font-size: 2rem;
  }
}

h3 {
  font-size: calc(1.3rem + .6vw);

  @media (width >= 1200px) {
    font-size: 1.75rem;
  }
}

h4 {
  font-size: calc(1.275rem + .3vw);

  @media (width >= 1200px) {
    font-size: 1.5rem;
  }
}

h5 {
  font-size: 1.25rem;
}

h6 {
  font-size: 1rem;
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
}

abbr[title] {
  text-decoration: underline dotted;
  cursor: help;
  text-decoration-skip-ink: none;
}

address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit;
}

ol, ul {
  padding-left: 2rem;
}

ol, ul, dl {
  margin-top: 0;
  margin-bottom: 1rem;
}

ol ol, ul ul, ol ul, ul ol {
  margin-bottom: 0;
}

dt {
  font-weight: 700;
}

dd {
  margin-bottom: .5rem;
  margin-left: 0;
}

blockquote {
  margin: 0 0 1rem;
}

b, strong {
  font-weight: bolder;
}

small {
  font-size: .875em;
}

mark {
  padding: .1875em;
  color: #000;
  background-color: #fff3cd;
}

sub, sup {
  position: relative;
  font-size: .75em;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -.25em;
}

sup {
  top: -.5em;
}

a {
  color: #0d6efd;
  opacity: 1;
  text-decoration: underline;

  &:hover {
    color: #0a58ca;
  }
}

pre, code, kbd, samp {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
  font-size: 1em;
}

pre {
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: .875em;

  & code {
    font-size: inherit;
    color: inherit;
    word-break: normal;
  }
}

code {
  font-size: 1em;
  word-wrap: break-word;

  a > & {
    color: inherit;
  }
}

kbd {
  padding: .1875rem .375rem;
  font-size: .875em;
  color: #fff;
  background-color: #212529;
  border-radius: .25rem;

  & kbd {
    padding: 0;
    font-size: 1em;
  }
}

figure {
  margin: 0 0 1rem;
}

img, svg {
  vertical-align: middle;
}

table {
  caption-side: bottom;
  border-collapse: collapse;
}

caption {
  padding-top: .5rem;
  padding-bottom: .5rem;
  color: #212529bf;
  text-align: left;
}

th {
  text-align: inherit;
  text-align: -webkit-match-parent;
}

thead, tbody, tfoot, tr, td, th {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}

label {
  display: inline-block;
}

button {
  border-radius: 0;
}

button:focus:not(:focus-visible) {
  outline: 0;
}

input, button, select, optgroup, textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

button, select {
  text-transform: none;
}

[role="button"] {
  cursor: pointer;
}

select {
  word-wrap: normal;

  &:disabled {
    opacity: 1;
  }
}

[list]:not([type="date"]):not([type="datetime-local"]):not([type="month"]):not([type="week"]):not([type="time"])::-webkit-calendar-picker-indicator {
  display: none !important;
}

button, [type="button"], [type="reset"], [type="submit"] {
  appearance: button;
  -webkit-appearance: button;

  &:not(:disabled) {
    cursor: pointer;
  }
}

::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

textarea {
  resize: vertical;
}

fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}

legend {
  float: left;
  width: 100%;
  padding: 0;
  margin-bottom: .5rem;
  line-height: inherit;
  font-size: calc(1.275rem + .3vw);

  & + * {
    clear: left;
  }
}

::-webkit-datetime-edit-fields-wrapper, ::-webkit-datetime-edit-text, ::-webkit-datetime-edit-minute, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-year-field {
  padding: 0;
}

::-webkit-inner-spin-button {
  height: auto;
}

[type="search"] {
  appearance: textfield;
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-color-swatch-wrapper {
  padding: 0;
}

::file-selector-button {
  font: inherit;
  appearance: button;
  -webkit-appearance: button;
}

output {
  display: inline-block;
}

iframe {
  border: 0;
}

summary {
  display: list-item;
  cursor: pointer;
}

progress {
  vertical-align: baseline;
}

[hidden] {
  display: none !important;
}

grid-2 {
  display: grid;
  gap: 1rem;

  @media (width >= 992px) {
    grid-template-columns: repeat(2, 1fr);
  }
}

grid-3 {
  display: grid;
  gap: 1rem;

  @media (width >= 992px) {
    grid-template-columns: repeat(3, 1fr);
  }
}

grid-4 {
  display: grid;
  gap: 1rem;

  @media (width >= 992px) {
    grid-template-columns: repeat(4, 1fr);
  }
}

grid-12 {
  display: grid;
  gap: 1rem;

  @media (width >= 992px) {
    grid-template-columns: repeat(12, 1fr);
  }
}

grid-2, grid-3, grid-4, grid-12 {
  @media (width >= 992px) {
    & cell-2 {
      grid-column: span 2;
    }

    & cell-3 {
      grid-column: span 3;
    }

    & cell-4 {
      grid-column: span 4;
    }

    & cell-5 {
      grid-column: span 5;
    }

    & cell-6 {
      grid-column: span 6;
    }

    & cell-7 {
      grid-column: span 7;
    }

    & cell-8 {
      grid-column: span 8;
    }

    & cell-9 {
      grid-column: span 9;
    }

    & cell-10 {
      grid-column: span 10;
    }
  }
}

hbox {
  display: flex;
  flex-direction: row;
  gap: 1rem;
  justify-content: space-between;

  &.wrap {
    flex-wrap: wrap;
  }
}

vbox {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

label-tag {
  display: inline-block;
  white-space: nowrap;
  padding: .35em .65em;
  font-size: .75em;
  font-weight: 700;
  line-height: 1;
  color: #fff;
  text-align: center;
  border-radius: .25rem;

  &.default {
    background-color: #6c757d;
  }

  &.primary {
    background-color: #0d6efd;
  }

  &.success {
    background-color: #198754;
  }

  &.info {
    background-color: #0dcaf0;
    color: #212529;
  }

  &.warning {
    background-color: #ffc107;
    color: #212529;
  }

  &.danger {
    background-color: #dc3545;
  }
}

alert {
  display: block;
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid #0000;
  border-radius: .25rem;
  font-size: 1rem;

  &.primary {
    color: #084298;
    background-color: #cfe2ff;
    border-color: #b6d4fe;

    & a {
      color: #084298;
      font-weight: 600;
      text-decoration: underline;
    }

    &.icon {
      &:before {
        content: "";
        font-family: "Font Awesome 5 Free";
        font-weight: 400;
      }
    }
  }

  &.success {
    color: #0f5132;
    background-color: #d1e7dd;
    border-color: #badbcc;

    & a {
      color: #0f5132;
      font-weight: 600;
      text-decoration: underline;
    }

    &.icon {
      &:before {
        content: "";
        font-family: "Font Awesome 5 Free";
        font-weight: 400;
      }
    }
  }

  &.danger {
    color: #842029;
    background-color: #f8d7da;
    border-color: #f5c2c7;

    & a {
      color: #842029;
      font-weight: 600;
      text-decoration: underline;
    }

    &.icon {
      &:before {
        content: "";
        font-family: "Font Awesome 5 Free";
        font-weight: 400;
      }
    }
  }

  &.warning {
    color: #664d03;
    background-color: #fff3cd;
    border-color: #ffecb5;

    & a {
      color: #664d03;
      font-weight: 600;
      text-decoration: underline;
    }

    &.icon {
      &:before {
        content: "";
        font-family: "Font Awesome 5 Free";
        font-weight: 400;
      }
    }
  }

  &.info {
    color: #055160;
    background-color: #cff4fc;
    border-color: #b6effb;

    & a {
      color: #055160;
      font-weight: 600;
      text-decoration: underline;
    }

    &.icon {
      &:before {
        content: "🔔";
      }
    }
  }
}

button {
  display: inline-block;
  color: #333;
  text-align: center;
  vertical-align: middle;
  background-color: #fff;
  border: 1px solid #ccc;
  padding: .375rem .75rem;
  font-size: 1rem;
  border-radius: .375rem;
  transition: background-color .15s ease-in-out, border-color .15s ease-in-out;

  &:hover {
    background-color: #e6e6e6;
    border-color: #adadad;
  }

  &:disabled {
    cursor: not-allowed;
    opacity: .65;

    &:hover {
      background-color: #fff;
      border-color: #ccc;
    }
  }

  &:focus {
    outline: 0;
    color: #333;
    background-color: #fff;
    border-color: #565e64;
    box-shadow: 0 0 0 .25rem #828a9180;
  }

  &.xs {
    padding: .125rem .25rem;
    font-size: .8125rem;
  }

  &.sm {
    padding: .25rem .5rem;
    font-size: .875rem;
  }

  &.lg {
    padding: .5rem 1rem;
    font-size: 1.25rem;
  }

  &.block {
    display: block;
    width: 100%;
  }

  &.primary {
    color: #fff;
    background-color: #0d6efd;
    border-color: #0d6efd;

    &:hover {
      background-color: #0a58ca;
      border-color: #0a58ca;

      &:disabled {
        background-color: #0d6efd;
        border-color: #0d6efd;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #0b5ed7;
      border-color: #07377f;
      box-shadow: 0 0 0 .25rem #3184fd80;
    }
  }

  &.secondary {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d;

    &:hover {
      background-color: #565e64;
      border-color: #565e64;

      &:disabled {
        background-color: #6c757d;
        border-color: #6c757d;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #5c636a;
      border-color: #363b3f;
      box-shadow: 0 0 0 .25rem #828a9180;
    }
  }

  &.success {
    color: #fff;
    background-color: #198754;
    border-color: #198754;

    &:hover {
      background-color: #146c43;
      border-color: #146c43;

      &:disabled {
        background-color: #198754;
        border-color: #198754;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #157347;
      border-color: #0d442a;
      box-shadow: 0 0 0 .25rem #3c996e80;
    }
  }

  &.danger {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545;

    &:hover {
      background-color: #b02a37;
      border-color: #b02a37;

      &:disabled {
        background-color: #dc3545;
        border-color: #dc3545;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #bb2d3b;
      border-color: #6e1b23;
      box-shadow: 0 0 0 .25rem #e1536180;
    }
  }

  &.warning {
    color: #000;
    background-color: #ffc107;
    border-color: #ffc107;

    &:hover {
      background-color: #ffcd39;
      border-color: #ffcd39;

      &:disabled {
        background-color: #ffc107;
        border-color: #ffc107;
      }
    }

    &:focus {
      outline: 0;
      color: #000;
      background-color: #ffca2c;
      border-color: #806104;
      box-shadow: 0 0 0 .25rem #d9a40680;
    }
  }

  &.info {
    color: #000;
    background-color: #0dcaf0;
    border-color: #0dcaf0;

    &:hover {
      background-color: #3dd5f3;
      border-color: #3dd5f3;

      &:disabled {
        background-color: #0dcaf0;
        border-color: #0dcaf0;
      }
    }

    &:focus {
      outline: 0;
      color: #000;
      background-color: #31d2f2;
      border-color: #076578;
      box-shadow: 0 0 0 .25rem #0baccc80;
    }
  }
}

a.btn {
  display: inline-block;
  color: #333;
  text-align: center;
  vertical-align: middle;
  cursor: pointer;
  background-color: #fff;
  border: 1px solid #ccc;
  padding: .375rem .75rem;
  font-size: 1rem;
  border-radius: .375rem;
  transition: background-color .15s ease-in-out, border-color .15s ease-in-out;
  white-space: nowrap;
  text-decoration: none;

  &:hover {
    background-color: #e6e6e6;
    border-color: #adadad;
  }

  &.disabled {
    cursor: not-allowed;
    opacity: .65;
    background-color: #fff;
    border-color: #ccc;

    &:hover {
      background-color: #fff;
      border-color: #ccc;
    }
  }

  &:focus {
    outline: 0;
    color: #333;
    background-color: #fff;
    border-color: #565e64;
    box-shadow: 0 0 0 .25rem #828a9180;
  }

  &.xs {
    padding: .125rem .25rem;
    font-size: .8125rem;
  }

  &.sm {
    padding: .25rem .5rem;
    font-size: .875rem;
  }

  &.lg {
    padding: .5rem 1rem;
    font-size: 1.25rem;
  }

  &.block {
    display: block;
    width: 100%;
  }

  &.primary {
    color: #fff;
    background-color: #0d6efd;
    border-color: #0d6efd;

    &:hover {
      background-color: #0a58ca;
      border-color: #0a58ca;

      &.disabled {
        background-color: #0d6efd;
        border-color: #0d6efd;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #0b5ed7;
      border-color: #07377f;
      box-shadow: 0 0 0 .25rem #3184fd80;
    }
  }

  &.secondary {
    color: #fff;
    background-color: #6c757d;
    border-color: #6c757d;

    &:hover {
      background-color: #565e64;
      border-color: #565e64;

      &:disabled {
        background-color: #6c757d;
        border-color: #6c757d;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #5c636a;
      border-color: #363b3f;
      box-shadow: 0 0 0 .25rem #828a9180;
    }
  }

  &.success {
    color: #fff;
    background-color: #198754;
    border-color: #198754;

    &:hover {
      background-color: #146c43;
      border-color: #146c43;

      &:disabled {
        background-color: #198754;
        border-color: #198754;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #157347;
      border-color: #0d442a;
      box-shadow: 0 0 0 .25rem #3c996e80;
    }
  }

  &.danger {
    color: #fff;
    background-color: #dc3545;
    border-color: #dc3545;

    &:hover {
      background-color: #b02a37;
      border-color: #b02a37;

      &:disabled {
        background-color: #dc3545;
        border-color: #dc3545;
      }
    }

    &:focus {
      outline: 0;
      color: #fff;
      background-color: #bb2d3b;
      border-color: #6e1b23;
      box-shadow: 0 0 0 .25rem #e1536180;
    }
  }

  &.warning {
    color: #000;
    background-color: #ffc107;
    border-color: #ffc107;

    &:hover {
      background-color: #ffcd39;
      border-color: #ffcd39;

      &:disabled {
        background-color: #ffc107;
        border-color: #ffc107;
      }
    }

    &:focus {
      outline: 0;
      color: #000;
      background-color: #ffca2c;
      border-color: #806104;
      box-shadow: 0 0 0 .25rem #d9a40680;
    }
  }

  &.info {
    color: #000;
    background-color: #0dcaf0;
    border-color: #0dcaf0;

    &:hover {
      background-color: #3dd5f3;
      border-color: #3dd5f3;

      &:disabled {
        background-color: #0dcaf0;
        border-color: #0dcaf0;
      }
    }

    &:focus {
      outline: 0;
      color: #000;
      background-color: #31d2f2;
      border-color: #076578;
      box-shadow: 0 0 0 .25rem #0baccc80;
    }
  }
}

a.stretched-link:after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  content: "";
}

panel {
  display: block;
  background-color: #fff;
  border-radius: .25rem;
  border: 1px solid #00000020;
  margin-bottom: 1rem;

  & > header {
    padding: .5rem 1rem;
    background-color: #f7f7f7;
    border-bottom: 1px solid #00000020;
    border-radius: .25rem .25rem 0 0;

    & h5 {
      margin: 0;
      font-weight: 500;
      font-size: 1.25rem;
    }
  }

  & > content {
    display: block;
    padding: 1rem;
  }

  & > footer {
    padding: .5rem 1rem;
    background-color: #f7f7f7;
    border-top: 1px solid #00000020;
    border-radius: 0 0 .25rem .25rem;
    margin: 0;
    text-align: center;
    display: flex;
    justify-content: center;
    gap: .25rem;
  }
}

.text-start {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-end {
  text-align: right;
}

.w-25 {
  width: 25%;
}

.w-50 {
  width: 50%;
}

.w-75 {
  width: 75%;
}

.w-100 {
  width: 100%;
}

.mw-100 {
  max-width: 100%;
}

.bux-narrow-sm {
  width: 100%;

  @container content-container (width >= 576px) {
    width: 540px;
    margin: 0 auto;
  }
}

.bux-narrow-md {
  width: 100%;

  @container content-container (width >= 768px) {
    width: 720px;
    margin: 0 auto;
  }
}

.bux-narrow-lg {
  width: 100%;

  @container content-container (width >= 992px) {
    width: 960px;
    margin: 0 auto;
  }
}

.m-0 {
  margin: 0;
}

.m-1 {
  margin: .25rem;
}

.m-2 {
  margin: .5rem;
}

.m-3 {
  margin: 1rem;
}

.m-4 {
  margin: 1.5rem;
}

.m-5 {
  margin: 3rem;
}

.m-auto {
  margin: auto;
}

.mt-0 {
  margin-top: 0;
}

.mt-1 {
  margin-top: .25rem;
}

.mt-2 {
  margin-top: .5rem;
}

.mt-3 {
  margin-top: 1rem;
}

.mt-4 {
  margin-top: 1.5rem;
}

.mt-5 {
  margin-top: 3rem;
}

.mt-auto {
  margin-top: auto;
}

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

.mb-1 {
  margin-bottom: .25rem;
}

.mb-2 {
  margin-bottom: .5rem;
}

.mb-3 {
  margin-bottom: 1rem;
}

.mb-4 {
  margin-bottom: 1.5rem;
}

.mb-5 {
  margin-bottom: 3rem;
}

.mb-auto {
  margin-bottom: auto;
}

.ms-0 {
  margin-left: 0;
}

.ms-1 {
  margin-left: .25rem;
}

.ms-2 {
  margin-left: .5rem;
}

.ms-3 {
  margin-left: 1rem;
}

.ms-4 {
  margin-left: 1.5rem;
}

.ms-5 {
  margin-left: 3rem;
}

.ms-auto {
  margin-left: auto;
}

.me-0 {
  margin-right: 0;
}

.me-1 {
  margin-right: .25rem;
}

.me-2 {
  margin-right: .5rem;
}

.me-3 {
  margin-right: 1rem;
}

.me-4 {
  margin-right: 1.5rem;
}

.me-5 {
  margin-right: 3rem;
}

.me-auto {
  margin-right: auto;
}

.p-0 {
  padding: 0;
}

.p-1 {
  padding: .25rem;
}

.p-2 {
  padding: .5rem;
}

.p-3 {
  padding: 1rem;
}

.p-4 {
  padding: 1.5rem;
}

.p-5 {
  padding: 3rem;
}

.pt-0 {
  padding-top: 0;
}

.pt-1 {
  padding-top: .25rem;
}

.pt-2 {
  padding-top: .5rem;
}

.pt-3 {
  padding-top: 1rem;
}

.pt-4 {
  padding-top: 1.5rem;
}

.pt-5 {
  padding-top: 3rem;
}

.pb-0 {
  padding-bottom: 0;
}

.pb-1 {
  padding-bottom: .25rem;
}

.pb-2 {
  padding-bottom: .5rem;
}

.pb-3 {
  padding-bottom: 1rem;
}

.pb-4 {
  padding-bottom: 1.5rem;
}

.pb-5 {
  padding-bottom: 3rem;
}

.ps-0 {
  padding-left: 0;
}

.ps-1 {
  padding-left: .25rem;
}

.ps-2 {
  padding-left: .5rem;
}

.ps-3 {
  padding-left: 1rem;
}

.ps-4 {
  padding-left: 1.5rem;
}

.ps-5 {
  padding-left: 3rem;
}

.pe-0 {
  padding-right: 0;
}

.pe-1 {
  padding-right: .25rem;
}

.pe-2 {
  padding-right: .5rem;
}

.pe-3 {
  padding-right: 1rem;
}

.pe-4 {
  padding-right: 1.5rem;
}

.pe-5 {
  padding-right: 3rem;
}

.gap-0 {
  gap: 0;
}

.gap-1 {
  gap: 1rem;
}

.gap-2 {
  gap: 2rem;
}

.gap-3 {
  gap: 3rem;
}

.gap-4 {
  gap: 4rem;
}

.gap-5 {
  gap: 5rem;
}

.r-gap-0 {
  row-gap: 0;
}

.r-gap-1 {
  row-gap: 1rem;
}

.r-gap-2 {
  row-gap: 2rem;
}

.r-gap-3 {
  row-gap: 3rem;
}

.r-gap-4 {
  row-gap: 4rem;
}

.r-gap-5 {
  row-gap: 5rem;
}

.c-gap-0 {
  column-gap: 0;
}

.c-gap-1 {
  column-gap: 1rem;
}

.c-gap-2 {
  column-gap: 2rem;
}

.c-gap-3 {
  column-gap: 3rem;
}

.c-gap-4 {
  column-gap: 4rem;
}

.c-gap-5 {
  column-gap: 5rem;
}

table {
  width: 100%;
  border-color: #dee2e6;
  margin-bottom: 1rem;
  caption-side: bottom;
  border-collapse: collapse;

  & > thead {
    vertical-align: bottom;
  }

  & > :not(:last-child) > :last-child > * {
    border-bottom-color: #212529;
  }

  & tbody, & td, & tfoot, & th, & thead, & tr {
    border-color: inherit;
    border-style: solid;
    border-width: 0;
  }

  & > :not(caption) > * > * {
    padding: .5rem;
    border-bottom-width: 1px;
  }
}

table-wrapper.data-list {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  display: block;

  & table {
    width: 100%;
    min-width: 600px;
    background-color: #fff;
    border-radius: .25rem;
    border: 1px solid #00000020;

    & thead {
      & tr {
        & th {
          padding: .5rem;
          border-bottom: 1px solid #212529;
          font-weight: bold;
          background-color: #f7f7f7;
        }

        & th:last-child {
          text-align: right;
        }
      }
    }

    & tbody {
      & tr {
        & th, & td {
          padding: .5rem;
          border-bottom: 1px solid #dee2e6;
          vertical-align: top;
        }
      }

      & th {
        font-weight: bold;
      }

      & td:last-child {
        text-align: right;
      }
    }
  }

  @media (width <= 991.98px) {
    display: block;
    overflow-x: auto;
  }
}

table-wrapper.detail-list {
  & table {
    width: 100%;
    border: 1px solid #00000020;
    background-color: #fff;
    border-radius: .25rem;

    & thead {
      & tr {
        & th {
          padding: .5rem;
          border-bottom: 1px solid #212529;
          font-weight: bold;
        }
      }
    }

    & tbody {
      & tr {
        & th, & td {
          padding: .5rem;
          border-bottom: 1px solid #dee2e6;
          vertical-align: top;
        }
      }

      & th {
        font-weight: bold;
      }
    }
  }
}

list-group {
  & ul {
    padding-left: 0;
    margin-bottom: 0;
    list-style-type: none;
    border-radius: .25rem;

    & li {
      padding: .5rem 1rem;
      background-color: #fff;
      border: 1px solid #00000020;

      &:first-child {
        border-top-left-radius: .25rem;
        border-top-right-radius: .25rem;
      }

      &:last-child {
        border-bottom-right-radius: .25rem;
        border-bottom-left-radius: .25rem;
      }
    }

    & li + li {
      border-top-width: 0;
    }
  }

  & ol {
    padding-left: 0;
    margin-bottom: 0;
    border-radius: .25rem;

    & li {
      padding: .5rem 1rem;
      background-color: #fff;
      border: 1px solid #00000020;
      list-style-position: inside;

      &:first-child {
        border-top-left-radius: .25rem;
        border-top-right-radius: .25rem;
      }

      &:last-child {
        border-bottom-right-radius: .25rem;
        border-bottom-left-radius: .25rem;
      }
    }

    & li + li {
      border-top-width: 0;
    }
  }

  &.flush {
    & ul {
      border-radius: 0;

      & li {
        border-width: 0 0 1px;

        &:last-child {
          border-bottom-width: 0;
        }
      }
    }

    & ol {
      border-radius: 0;

      & li {
        border-width: 0 0 1px;

        &:last-child {
          border-bottom-width: 0;
        }
      }
    }
  }

  &.action {
    & ul {
      & li {
        padding: 0;

        & a {
          text-decoration: none;
          display: block;
          padding: .5rem 1rem;
          color: #212529;

          &:hover, &:focus {
            background-color: #f8f9fa;
            color: #495057;
          }

          &.active {
            color: #fff;
            background-color: #0d6efd;
            border-color: #0d6efd;
          }

          &.disabled {
            color: #6c757d;
            pointer-events: none;
            background-color: #fff;
          }
        }

        &:first-child {
          & a {
            border-top-left-radius: .25rem;
            border-top-right-radius: .25rem;
          }
        }

        &:last-child {
          & a {
            border-bottom-right-radius: .25rem;
            border-bottom-left-radius: .25rem;
          }
        }
      }
    }
  }
}

bux-hr-list {
  & ul {
    margin: 0;
    display: flex;
    list-style: none;
    padding: 0;
    border: 1px solid #ccc;

    & li {
      flex: 1;
      text-align: center;
      border-right: 1px solid #ccc;
      background: #fff;
      padding: .2rem;
      font-weight: bold;
    }
  }
}

bux-action-panel {
  margin: 0 auto;
  display: block;
  width: 50% !important;
}

@media (width <= 992px) {
  bux-action-panel {
    max-width: 100%;
    width: 100% !important;
  }
}

input.bux-search {
  width: 30%;
  margin-bottom: 1rem;
  padding: .5rem 1rem;
  border: 1px solid #ced4da;
  border-radius: .25rem;
  font-size: 1rem;
}

bux-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .5rem 1rem;
  background-color: #f7f7f7;
  border: 1px solid #00000020;
  border-radius: .25rem .25rem 0 0;
}

bux-border-panel {
  margin: 0 auto;
  display: block;
  border: 1px solid #00000020;
  padding: 1rem;
  width: 50% !important;
}

@media (width <= 992px) {
  bux-border-panel {
    max-width: 100%;
    width: 100% !important;
  }
}

body > layout-wrapper-outer > footer {
  & ul#footer-links {
    padding-left: 0;
    margin: 0;
    list-style-type: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: .5rem;

    & li {
      display: inline-block;

      & a {
        color: var(--bux-footer-color);
      }
    }

    &.disabled {
      display: none;
    }

    @media (width >= 768px) {
      flex-direction: row;
      gap: 1.5rem;
    }
  }
}

:root {
  --bux-footer-social-color: #6b6b6b;
}

body > layout-wrapper-outer > footer {
  & ul#footer-socials {
    padding-left: 0;
    margin: 0;
    list-style-type: none;
    display: flex;
    align-items: center;
    column-gap: 1rem;
    justify-content: center;

    & li {
      display: inline-block;

      & a {
        color: var(--bux-footer-social-color);
        font-size: 10pt;
      }
    }

    &.disabled {
      display: none;
    }
  }
}

:root {
  --bux-page-nav-bg-color: #e4e6e7;
  --bux-page-nav-border-bottom: 1px solid #c4c7ca;
  --bux-page-nav-a-color: #4e4eff;
  --bux-page-nav-a-hover-color: red;
  --bux-page-nav-a-fw: 500;
  --bux-page-nav-a-bg-color: #fff;
  --bux-page-nav-a-border: 1px solid #fff;
  --bux-page-nav-a-selected-td: underline;
  --bux-page-nav-a-selected-color: #fff;
  --bux-page-nav-a-selected-hover-color: red;
  --bux-page-nav-a-selected-fw: inherit;
  --bux-page-nav-a-selected-bg-color: #707070;
  --bux-page-nav-a-selected-border-color: #707070;
}

page-nav-wrapper {
  display: block;
  padding: .5rem 0;
  background-color: var(--bux-page-nav-bg-color);
  border-bottom: var(--bux-page-nav-border-bottom);

  & content-container {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: flex-start;

    & nav#page-navigation {
      & ul {
        padding-left: 0;
        margin-bottom: 0;
        display: flex;
        flex-wrap: wrap;
        gap: .5rem;

        & li {
          list-style-type: none;
          display: inline-block;
          vertical-align: middle;

          & a {
            text-decoration: underline;
            color: var(--bux-page-nav-a-color);
            font-weight: var(--bux-page-nav-a-fw);
            display: block;
            background-color: var(--bux-page-nav-a-bg-color);
            border: var(--bux-page-nav-a-border);
            padding: .25rem .5rem;
            font-size: .875rem;
            border-radius: .375rem;

            & u:before {
              content: " 🞂 ";
            }

            &.selected {
              text-decoration: var(--bux-page-nav-a-selected-td);
              color: var(--bux-page-nav-a-selected-color);
              font-weight: var(--bux-page-nav-a-selected-fw);
              background-color: var(--bux-page-nav-a-selected-bg-color);
              border-color: var(--bux-page-nav-a-selected-border-color);
            }

            &.external-link {
              display: flex;
              column-gap: .5rem;
              align-items: center;
            }
          }

          & a:hover {
            color: var(--bux-page-nav-a-hover-color);

            &.selected {
              color: var(--bux-page-nav-a-selected-hover-color);
            }
          }
        }
      }
    }

    & button-wrapper {
      margin-left: auto;
      display: flex;
      gap: .25rem;
    }
  }
}

bux-floater {
  visibility: hidden;
  display: block;
  position: absolute;
  width: "max-content";
  top: 0;
  left: 0;
  border: .05rem solid #666;
  border-radius: .5rem;
  background-color: #fff;
  margin: .5rem;

  & > x-title {
    background-color: #ccc;
    padding: .25rem 1rem;
    display: flex;
    border-top-left-radius: .5rem;
    border-top-right-radius: .5rem;

    & > span {
      font-weight: bold;
      flex: 1;
    }

    & > a {
      margin-left: 1rem;
    }
  }

  & > x-content {
    display: block;
    padding: .5rem 1rem;
  }
}

bux-floater.InfoBox {
  max-width: 40rem;
}

bux-floater.SearchSimple {
  & x-search {
    display: flex;
    gap: 10pt;
  }

  & x-result {
    display: none;
    margin-top: 1rem;
    border-top: 1pt solid #ccc;
  }
}
