
:root {

  font-family: var(--ui-font-family);
  font-size: 15px;

  /* Greys */
  --ui-color-grey-50:  rgb(249 250 251);
  --ui-color-grey-100: rgb(243 244 246);
  --ui-color-grey-200: rgb(229 231 235);
  --ui-color-grey-300: rgb(209 213 219);
  --ui-color-grey-400: rgb(156 163 175);
  --ui-color-grey-500: rgb(107 114 128);
  --ui-color-grey-600: rgb(75 85 99);
  --ui-color-grey-700: rgb(55 65 81);
  --ui-color-grey-800: rgb(31 41 55);
  --ui-color-grey-900: rgb(17 24 39);
  --ui-color-grey-950: rgb(3 7 18);

  /* Colors */
  --ui-color-primary: var(--ui-color-grey-700); /* Dark Grey */
  --ui-color-primary-hover: #000; /* Slightly Darker Grey */
  --ui-color-primary-faded: #afb8c133; /* Light Grey */
  --ui-color-primary-text: #efefef; 

  /* Fonts */
  --ui-font-family: 'Inter', sans-serif;
  --ui-font-family-headers: 'Inter', sans-serif;

  /* Font Sizes */
  --ui-font-size-xl: 1.6rem;
  --ui-font-size-lg: 1.2rem;
  --ui-font-size: 1rem;
  --ui-font-size-md: 0.9rem;
  --ui-font-size-sm: 0.75rem;

  /* Font Weights */
  --ui-font-weight-light: 300;
  --ui-font-weight-normal: 400;
  --ui-font-weight-bold: 700;
  --ui-font-weight-extrabold: 900;

  /* Shared */
  --ui-shared-border-radius: 6px;
  --ui-shared-border-width: 2px;
  --ui-shared-box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.1);
  --ui-border-radius-buttons: var(--ui-shared-border-radius);
  --ui-shared-content-padding: 1.2rem;
  --ui-shared-padding-md: 0.75rem;
  --ui-shared-link-color: #191919;

  /* Buttons */
  --ui-button-plain-color: var(--ui-color-grey-900);
  --ui-button-plain-background-hover: var(--ui-color-grey-100);
  --ui-button-padding: 0.5rem 0.8rem;
  --ui-button-border-width: 1px;
  --ui-button-border-color: var(--ui-color-grey-300);

  /* Toggle */
  --ui-toggle-width: 20px;
  --ui-toggle-padding: 3px;
  --ui-toggle-background-inactive: var(--ui-color-grey-200);
  --ui-toggle-background-hover: var(--ui-color-grey-400);
  --ui-toggle-background-active: rgb(74 222 128);
  --ui-toggle-box-shadow: var(--ui-shared-box-shadow);

  /* Button Groups */
  --ui-button-group-border-color: var(--ui-color-grey-200);
  --ui-button-group-border-width: 2px;

  /* Form Inputs */
  --ui-input-color: var(--ui-color-grey-800);
  --ui-form-input-padding-small-screens: 0.5rem 0rem;
  --ui-form-input-width: 100%;
  --ui-input-border-radius: var(--ui-shared-border-radius);
  --ui-input-border-width: var(--ui-shared-border-width);
  --ui-input-padding: 0.75rem;
  --ui-form-input-border-color: var(--ui-color-grey-200);
  --ui-form-input-border-color-focus: var(--ui-color-grey-900);
  --ui-form-input-border-color-invalid: rgba(239, 68, 68);
  --ui-form-input-height: 3rem;
  --ui-form-input-line-height: 1rem;
  --ui-form-select-line-height: 1.2rem;

  /* Floating Labels */
  --ui-floating-label-color: var(--ui-color-grey-900);
  --ui-floating-label-color-placeholder: var(--ui-color-grey-400);
  --ui-floating-label-padding-left: 0.8rem;
  --ui-floating-label-collapsed-size: 0.75rem;
  --ui-floating-label-collapsed-padding: 2px 4px;
  --ui-floating-label-bg-color: #fff;

  /* Search Input */
  --ui-search-input-border-width: var(--ui-input-border-width);
  --ui-search-input-border-radius: 40px;

  /* Boxes */ 
  --ui-box-box-shadow: var(--ui-shared-box-shadow);
  --ui-box-border: none;
  --ui-box-border-radius: var(--ui-shared-border-radius);
  --ui-box-padding: var(--ui-shared-content-padding);
  --ui-box-background: #fff;
  --ui-box-separator-border: 2px solid var(--ui-color-grey-100);

  /* Modals */
  --ui-modal-overlay-color: rgba(0, 0, 0, 0.5);
  --ui-modal-overlay-opacity: 0.8;
  --ui-modal-background-color: var(--ui-box-background);
  --ui-modal-border-radius: var(--ui-shared-border-radius);
  --ui-modal-box-shadow: var(--ui-shared-box-shadow);
  --ui-modal-padding: var(--ui-shared-content-padding);
  --ui-modal-max-width: 600px;
  --ui-modal-max-width-xs: 400px;
  --ui-modal-max-width-sm: 500px;
  --ui-modal-max-width-lg: 700px;
  --ui-modal-max-width-xl: 800px;
  --ui-modal-max-width-2xl: 1000px;

  /* Toasts */
  --ui-toasts-position-top: 20px;
  --ui-toasts-position-right: 20px;
  --ui-toasts-max-width: 300px;
  --ui-toasts-box-shadow: var(--ui-shared-box-shadow);
  --ui-toasts-border-radius: var(--ui-shared-border-radius);
  --ui-toasts-gap: 1.3rem;
  --ui-toasts-toast-padding: 1rem;
  --ui-toasts-toast-color-title: var(--ui-title-pair-color-title);
  --ui-toasts-toast-color-description: var(--ui-title-pair-color-description);

  /* Tooltips */
  --ui-tooltip-background-color: var(--ui-color-grey-900);
  --ui-tooltip-text-color: #fff;
  --ui-tooltip-font-size: 0.85rem;
  --ui-tooltip-line-height: 1rem;
  --ui-tooltip-border-radius: var(--ui-shared-border-radius);
  --ui-tooltip-padding: var(--ui-shared-padding-md);
  --ui-tooltip-box-shadow: var(--ui-shared-box-shadow);

  /* Title Pairs */
  --ui-title-pair-color-title: var(--ui-color-grey-900);
  --ui-title-pair-color-description: var(--ui-color-grey-500);
  --ui-title-pair-font-size-2xl-title: 3rem;
  --ui-title-pair-font-size-2xl-description: 1.7rem;
  --ui-title-pair-font-size-xl-title: 2.6rem;
  --ui-title-pair-font-size-xl-description: 1.6rem;
  --ui-title-pair-font-size-lg-title: 2.3rem; 
  --ui-title-pair-font-size-lg-description: 1.4rem;
  --ui-title-pair-font-size-md-title: 2rem;
  --ui-title-pair-font-size-md-description: 1.2em;
  --ui-title-pair-font-size-title: 1.8rem;
  --ui-title-pair-font-size-description: 1.2rem;
  --ui-title-pair-font-size-sm-title: 1.3rem;
  --ui-title-pair-font-size-sm-description: 1rem;
  --ui-title-pair-font-size-xs-title: 1rem;
  --ui-title-pair-font-size-xs-description: 0.9rem;

  /* Tables */
  --ui-table-thead-background: var(--ui-color-grey-100);
  --ui-table-thead-border-radius: var(--ui-shared-border-radius);
  --ui-table-cell-padding-horizontal: 8px;
  --ui-table-cell-padding-vertical: 5px;

  /* Styled Text */
  --ui-styled-text-code-background: #1e293b;
  --ui-styled-text-code-border-radius: var(--ui-shared-border-radius);
  --ui-styled-text-link-color: var(--ui-shared-link-color);
  --ui-styled-text-link-text-decoration: underline;
  --ui-styled-text-link-text-decoration-thickness: 2px;
  --ui-styled-text-color: var(--ui-color-grey-500);
  --ui-styled-text-blockquote-padding: 1rem;
  --ui-styled-text-blockquote-background: var(--ui-color-grey-100);
  --ui-styled-text-blockquote-border-radius: var(--ui-shared-border-radius);

  /* Container */
  --ui-container-max-width: 1024px;
  --ui-container-max-width-xs: 480px;
  --ui-container-max-width-sm: 640px;
  --ui-container-max-width-md: 768px;
  --ui-container-max-width-lg:  1200px;
  --ui-container-max-width-xl: 1440px;
  --ui-container-max-width-2xl: 1536px;
  --ui-container-padding: 1rem;
  --ui-container-margin: 0 auto;
  
}

.ui-search-input {
  padding-left: var(--form-input-search-padding-left, 2.5rem) !important;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' aria-hidden='true' viewBox='0 0 24 24'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-4.35-4.35M17.5 11a6.5 6.5 0 1 1-13 0 6.5 6.5 0 0 1 13 0Z'/%3E%3C/svg%3E");
  background-position: left .5rem center;
  background-repeat: no-repeat;
  background-size: 1.5em 1.5em;
  border-radius:  var(--ui-search-input-border-radius);
  border-width:   var(--ui-search-input-border-width);
  padding:        var(--ui-form-input-padding-small-screens);
  height: var(--ui-form-input-height);
    line-height: var(--ui-form-input-line-height);
}

/* Forms */
.ui-form label:not(.no-style) {
  line-height: 2.5rem;
  font-weight: var(--ui-font-weight-bold);
  cursor: pointer;
}

.shown-while-loading {
  visibility:hidden; 
  width:0px !important; 
  height:0px; 
  overflow:hidden
}
button.htmx-request .shown-while-loading,
a.htmx-request .shown-while-loading,
form.htmx-request [type="submit"] .shown-while-loading { 
  width: auto !important; 
  visibility: visible 
}

.ui-form [type='text']:not(.no-style),
.ui-form [type='email']:not(.no-style),
.ui-form [type='url']:not(.no-style),
.ui-form [type='password']:not(.no-style),
.ui-form [type='number']:not(.no-style),
.ui-form [type='date']:not(.no-style),
.ui-form [type='datetime-local']:not(.no-style),
.ui-form [type='month']:not(.no-style),
.ui-form [type='search']:not(.no-style),
.ui-form [type='tel']:not(.no-style),
.ui-form [type='time']:not(.no-style),
.ui-form [type='week']:not(.no-style),
.ui-form [multiple]:not(.no-style),
.ui-form textarea:not(.no-style),
.ui-form select:not(.no-style) {
  border-width:   var(--ui-input-border-width);
  border-radius:  var(--ui-input-border-radius);
  padding:        var(--ui-form-input-padding-small-screens);
  width:          var(--ui-form-input-width);
  transition :    border 500ms ease-out;
}

.ui-form [type='text']:focus:not(.no-style),
.ui-form [type='email']:focus:not(.no-style),
.ui-form [type='url']:focus:not(.no-style),
.ui-form [type='password']:focus:not(.no-style),
.ui-form [type='number']:focus:not(.no-style),
.ui-form [type='date']:focus:not(.no-style),
.ui-form [type='datetime-local']:focus:not(.no-style),
.ui-form [type='month']:focus:not(.no-style),
.ui-form [type='search']:focus:not(.no-style),
.ui-form [type='tel']:focus:not(.no-style),
.ui-form [type='time']:focus:not(.no-style),
.ui-form [type='week']:focus:not(.no-style),
.ui-form [multiple]:focus:not(.no-style),
.ui-form textarea:focus:not(.no-style),
.ui-form select:focus:not(.no-style),
.ui-search-input:focus {
  outline: none;
  border-color:   var(--ui-form-input-border-color-focus);
}

@media (min-width: 640px) {
  .ui-form [type='text']:not(.no-style),
  .ui-form [type='email']:not(.no-style),
  .ui-form [type='url']:not(.no-style),
  .ui-form [type='password']:not(.no-style),
  .ui-form [type='number']:not(.no-style),
  .ui-form [type='date']:not(.no-style),
  .ui-form [type='datetime-local']:not(.no-style),
  .ui-form [type='month']:not(.no-style),
  .ui-form [type='search']:not(.no-style),
  .ui-form [type='tel']:not(.no-style),
  .ui-form [type='time']:not(.no-style),
  .ui-form [type='week']:not(.no-style),
  .ui-form [multiple]:not(.no-style),
  .ui-form textarea:not(.no-style),
  .ui-form select:not(.no-style) {
    font-size:      var(--ui-font-size);
    color:          var(--ui-input-color);
    font-weight:    var(--ui-font-weight-normal);
    border-color:   var(--ui-form-input-border-color);
    border-width:   var(--ui-input-border-width);
    border-radius:  var(--ui-input-border-radius);
    padding:        var(--ui-input-padding);
  }
  .ui-form [type='text']:not(.no-style).invalid,
  .ui-form [type='email']:not(.no-style).invalid,
  .ui-form [type='url']:not(.no-style).invalid,
  .ui-form [type='password']:not(.no-style).invalid,
  .ui-form [type='number']:not(.no-style).invalid,
  .ui-form [type='date']:not(.no-style).invalid,
  .ui-form [type='datetime-local']:not(.no-style).invalid,
  .ui-form [type='month']:not(.no-style).invalid,
  .ui-form [type='search']:not(.no-style).invalid,
  .ui-form [type='tel']:not(.no-style).invalid,
  .ui-form [type='time']:not(.no-style).invalid,
  .ui-form [type='week']:not(.no-style).invalid,
  .ui-form [multiple]:not(.no-style).invalid,
  .ui-form textarea:not(.no-style).invalid,
  .ui-form select:not(.no-style).invalid {
    border-color: var(--ui-form-input-border-color-invalid);
  }
}

.ui-floating-input {
  position: relative;
}

.ui-floating-input input:focus + label,
.ui-floating-input input:not(:placeholder-shown) + label {
  color: var(--ui-floating-label-color);
  left: var(--ui-floating-label-padding-left);
  font-size: var(--ui-floating-label-collapsed-size);
  background-color: var(--ui-floating-label-bg-color);
  padding: var(--ui-floating-label-collapsed-padding);
  top: 0px;
  line-height: unset;
}
.ui-floating-input label {
  color: var(--ui-floating-label-color-placeholder);
  left: var(--ui-floating-label-padding-left);
  line-height: unset;
  font-weight: normal !important;
  position: absolute;
  top: 50%;
  pointer-events: none;
  transform: translateY(-50%);
  transition: all 0.2s ease-in-out;
  z-index: 10;
}

.ui-form select:focus:not(.no-style).invalid {
  border-color: var(--ui-form-input-border-color-invalid, rgba(239, 68, 68));
}

.ui-form input:not([type="checkbox"]):not(.no-style), 
.ui-form select:not(.no-style) {
  height: var(--ui-form-input-height);
  line-height: var(--ui-form-input-line-height);
}

.ui-form select:not(.no-style) {
  line-height: var(--ui-form-select-line-height);
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' aria-hidden='true' viewBox='0 0 10 6'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m1 1 4 4 4-4'/%3E%3C/svg%3E");
  background-position: right .75rem center;
  background-repeat: no-repeat;
  background-size: .75em .75em;
  padding-inline-end: 2rem;
}

.ui-select {
  position: relative;
  .--trigger {
    border-width: var(--ui-input-border-width);
    border-color: var(--ui-form-input-border-color);
    border-radius: var(--ui-shared-border-radius);
    padding: var(--ui-input-padding);
    width: 100%;
    &:hover {
      background-color: var(--ui-color-primary-faded);
    }
  }
  .--drawer {
    z-index: 100;
    position: absolute;
    top: var(--ui-form-input-height);
    right: 0;
    left: 0;
    font-weight: var(--ui-font-weight-normal);
    background-color: white;
    opacity: 0;
    transform: scale(0.95);
    transition: opacity 0.1s ease-out, transform 0.1s ease-out;
    transform-origin: top left;
    pointer-events: none;
    max-height: 300px;
    overflow-y: auto;
    border-color: var(--ui-color-primary);
    border-width: var(--ui-shared-border-width);
    border-radius: var(--ui-shared-border-radius);
    border-top-width: 0;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
  }
  &.--open {
    .--trigger {
      border-color: var(--ui-form-input-border-color-focus);
      border-bottom-left-radius: 0;
      border-bottom-right-radius: 0;
      border-bottom-color: transparent;
    }
    .--drawer {
      opacity: 1;
      transform: scale(1);
      pointer-events: auto;
      .--options {
        & > *:not(.--searchbox) {
          width: 100%;
          padding: var(--ui-input-padding);
          &:hover {
            background-color: var(--ui-color-primary-faded);
          }
        }
      }
    }
  }
  .--searchbox {
    border-width: 0 !important;
    height: var(--ui-form-input-height);
    line-height: var(--ui-form-input-line-height);
    font-size: var(--ui-font-size);
    color: var(--ui-input-color);
    font-weight: var(--ui-font-weight-normal);
    padding: var(--ui-input-padding);
    width: var(--ui-form-input-width);
    transition: border 500ms ease-out;
    outline: none;
  }
}

.ui-box {
  border: var(--ui-box-border);
  box-shadow: var(--ui-box-box-shadow);
  padding:  var(--ui-box-padding);
  border-radius: var(--ui-box-border-radius);
  background: var(--ui-box-background);
  & > .--top,
  & > .--bottom,
  & > * > .--top,
  & > * > --bottom {
    display: flex;
    padding: var(--ui-box-padding);
    margin-left: calc(-1 * var(--ui-box-padding));
    margin-right: calc(-1 * var(--ui-box-padding));
    justify-content: space-between;
  }
  & > .--top,
  & > * > .--top {
    border-bottom: var(--ui-box-separator-border);
    margin-bottom: var(--ui-box-padding);
    margin-top: calc(-1 * var(--ui-box-padding));
  }
  & > .--bottom,
  & > * > .--bottom {
    border-top: var(--ui-box-separator-border);
    margin-top: var(--ui-box-padding);
    margin-bottom: calc(-1 * var(--ui-box-padding));
  }
}

.ui-button {
  position: relative;
  padding: var(--ui-button-padding);
  font-size: var(--ui-font-size);
  border-radius: var(--ui-border-radius-buttons);
  border-color: var(--ui-button-border-color);
  border-width: var(--ui-button-border-width);
  transition: all 0.2s;
  cursor: pointer;
  &:hover {
    background: var(--ui-button-plain-background-hover);
  }
  &.--minimal {
    border-color: transparent;
  }
  &.--rounded {
    border-radius: 50px;
  }
}
.ui-button.--solid {
  background-color: var(--ui-color-primary);
  color: var(--ui-color-primary-text);
  border-color: var(--ui-color-primary);
  &:hover {
    border-color: var(--ui-color-primary-hover);
    background-color: var(--ui-color-primary-hover);
  }
}

.ui-link,
.ui-button,
.ui-form button {
  text-overflow: ellipsis;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  column-gap: 0.5rem;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--ui-button-plain-color);
  svg {
    width: 19px;
    height: 19px;
    transition: transform 0.2s ease-in-out;
  }
  &.--icon {
    width: var(--ui-button-icon-dimension);
    height: var(--ui-button-icon-dimension);
    &.--small {
    }
  }
  &.--motion-forward svg,
  &.--motion-backward svg {
    transition: transform 0.2s ease-in-out;
  }
  &.--motion-forward:hover svg{
    transform: translateX(2px);
  }
  &.--motion-backward:hover svg {
    transform: translateX(-2px);
  }
  &.--motion-upward:hover svg {
    transform: translateY(-2px);
  }
  &.--motion-downward:hover svg {
    transform: translateY(2px);
  }
}

.ui-link {
  font-size: var(--ui-font-size);
  position: relative;
  line-height: 20px;
  align-self: center;
  cursor: pointer;
  color: var(--ui-color-primary);
}

.ui-button-group {
  color: var(--ui-color-primary);
  display: flex;
  & > * {
    display: flex;
    column-gap: 0.5rem;
    align-items: center;
    border-width: var(--ui-button-group-border-width);
    border-color: var(--ui-form-input-border-color);
    border-left-width: 0px;
    padding: var(--ui-button-padding);
    transition: all 0.2s;
    color: var(--ui-color-primary);
    cursor: pointer;
  }
  a:first-child, button:first-child {
    border-top-left-radius: var(--ui-border-radius-buttons);
    border-bottom-left-radius: var(--ui-border-radius-buttons);
    border-left-width: var(--ui-button-group-border-width);
  }
  a:last-child, button:last-child {
    border-top-right-radius: var(--ui-border-radius-buttons);
    border-bottom-right-radius: var(--ui-border-radius-buttons);
  }
  a:hover, button:hover {
    background-color: var(--ui-color-primary-faded);
  }
  svg {
    width: 14px;
    height: 14px;
  }
}

.ui-input-group,
.ui-form .ui-input-group {
  display: flex;
  input[type='text'] {
    position: relative;
    border-width: var(--ui-input-border-width);
    border-top-color: var(--ui-form-input-border-color);
    border-bottom-color: var(--ui-form-input-border-color); 
    border-radius: 0;
    margin-right: calc(-1 * var(--ui-input-border-width));
    z-index: 1;
  }
  input[type='text']:focus {
    z-index: 2;
  }
  & > input[type='text']:first-child {
    border-top-left-radius: var(--ui-border-radius-buttons);
    border-bottom-left-radius: var(--ui-border-radius-buttons);
    border-left-width: var(--ui-input-border-width);
  }
  & > input[type='text']:last-child {
    border-top-right-radius: var(--ui-border-radius-buttons);
    border-bottom-right-radius: var(--ui-border-radius-buttons);
  }
}

.ui-link:after {
  background-color: currentColor;
  height: 2px;
  position: absolute;
  right: 0;
  top: 100%;
  width: 0;
  --tw-translate-y: 0.25rem;
  content: var(--tw-content);
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
  transition-duration: .4s;
  transition-property: all;
  transition-timing-function: cubic-bezier(.59,0,.06,1);
}

.ui-link:hover:after { 
  left: 0;
  width: 100%;
} 

.ui-eyebrow {
  font-size: 10px;
  font-weight: normal;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--maroon-candy-color-apollo);
}

.ui-titlepair {
  display: flex;
  flex-direction: column;
  align-items: start;
  &.--center {
    align-items: center;
  }
  & > .--title,
  & > .--description {
    display: block;
  }
  & > .--title {
    font-size: var(--ui-title-pair-font-size-title);
    font-weight: var(--ui-font-weight-bold);
    color: var(--ui-title-pair-color-title);
    font-family: var(--ui-font-family-headers);
  }
  & > .--description {
    font-size: var(--ui-title-pair-font-size-description);
    font-weight: var(--ui-font-weight-light);
    color: var(--ui-title-pair-color-description);
  }
  &.--2xl {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-2xl-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-2xl-description);
    }
  }
  &.--xl {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-xl-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-xl-description);
    }
  }
  &.--lg {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-lg-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-lg-description);
    }
  }
  &.--md {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-md-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-md-description);
    }
  }
  &.--sm {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-sm-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-sm-description);
    }
  }
  &.--xs {
    & > .--title {
      font-size: var(--ui-title-pair-font-size-xs-title);
    }
    & > .--description {
      font-size: var(--ui-title-pair-font-size-xs-description);
    }
  }
}

.ui-tuple {
  width: 100%;
  .--item {
    padding: 11px 0;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid var(--ui-color-grey-100);
    font-size: 14px;
    .--left,
    .--right {
      justify-content: center;
      display: flex;
      flex-direction: column;
    }
    .--right {
      color: var(--maroon-candy-color-apollo);
    }
  }
}

.ui-tabnav {
  &.--ares {
    display: flex;
    font-size: var(--ui-font-size);
    line-height: calc(var(--ui-font-size) * 1.5);
    & > * {
      padding-bottom: 6px;
    }
    & > *.active {
      border-bottom-width: var(--ui-shared-border-width);
      border-color: var(--ui-color-primary);
      font-weight: var(--ui-font-weight-bold);
    }
    button,
    a {
      display: flex;
      justify-items: center; /* For Icon Alignment */
      transition-property: background-color;
      transition-duration: 300ms;
      gap: 4px;
      border-radius: var(--ui-shared-border-radius);
      padding: 0.5rem 1rem;
    }
    button:hover,
    a:hover {
      background: var(--ui-color-primary-faded);
    }
  }
  &.--hades {
    display: flex;
    font-size: var(--ui-font-size);
    line-height: calc(var(--ui-font-size) * 2.25);
    & > * {
      margin-right: 10px;
    }
    & > *.active {
      border-bottom-width: var(--ui-shared-border-width);
      border-color: var(--ui-color-primary);
    }
    button,
    a {
      cursor: pointer;
      justify-items: center; /* For Icon Alignment */
      transition-property: background-color;
      transition-duration: 300ms;
      gap: 4px;
      padding: 0.5rem 10px;
    }
    button:hover,
    a:hover {
      background: var(--ui-color-primary-faded);
    }
  }
}

.ui-table {
  width: 100%;
  text-align: left;
  thead {
    background-color: var(--ui-table-thead-background);
    border-radius: var(--ui-table-thead-border-radius);
  }
  th, td {
    padding: var(--ui-table-cell-padding-vertical) var(--ui-table-cell-padding-horizontal);
    width: 200px;
  }
}


.ui-toasts {
  position: fixed;
  max-width: var(--ui-toasts-max-width);
  top: var(--ui-toasts-position-top);
  right: var(--ui-toasts-position-right);
  z-index: 90;
  & > .--toast {
    transform: translateY(-120%);
    grid-template-rows: 1fr ;
    display: grid;
    opacity: 0;
    padding-bottom: var(--ui-toasts-gap);
    width: 300px;
    max-width: 300px;
    &.--animate-in {
      transition: 0.5s;
      transform: translateY(0%);
      opacity: 1;
    }
    &.--animate-out {
      transform: translateX(120%);
      transition: 0.5s;
      grid-template-rows: 0fr ;
      padding-bottom: 0px;
    }
    & > .--wrapper {
      overflow: hidden;
      box-shadow: var(--ui-toasts-box-shadow);
      border-radius: var(--ui-toasts-border-radius);
      .--dismiss {
        top: 5px;
        right: 5px; 
        position: absolute;
        color: #191919;
        padding: 8px;
        border-radius: 40px;
        cursor: pointer;
        svg {
          width: 20px;
          height: 20px;
        }
        &:hover {
          background-color: var(--ui-button-plain-background-hover);
        }
      }
      & > .--content {
        padding: var(--ui-toasts-toast-padding);
        position: relative;
        font-size: 0.9rem;
        line-height: 1.25rem;
        background: #fff;
        color: var(--ui-toasts-toast-color-description);
        & > .--title {
          color: var(--ui-toasts-toast-color-title);
          font-family: var(--ui-font-family-headers);
          font-weight: var(--ui-font-weight-bold);
          font-size: 1.1rem;
          line-height: 1.5rem;
          margin-bottom: 0.5rem;
          padding-right: 1rem;
          display: block;
          overflow: hidden;
          text-overflow: ellipsis;
          white-space: nowrap;
        }
      }
    }
  }
}

.ui-styled-text {
  line-height:  var(--ui-styled-text-line-height, 30px);
  color:        var(--ui-styled-text-color);
}
.ui-styled-text > h1,
.ui-styled-text > h2,
.ui-styled-text > h3,
.ui-styled-text > h4 {
  color:        var(--styled-text-heading-color, #191919);
  font-weight:  var(--styled-text-heading-font-weight, 800);
  font-family: var(--ui-font-family-headers);
}
.ui-styled-text > h1 {
  margin:         var(--styled-text-h1-margin, 0 0 20px 0);
  padding:        var(--styled-text-h1-padding, 0 0 10px 0);
  font-size:      var(--styled-text-h1-font-size, 32px);
  line-height:    var(--styled-text-h1-line-height, 1.2);
  border-bottom:  var(--styled-text-h1-bottom-border, 1px solid #d0d7deb3);
}
.ui-styled-text > h2 {
  margin:         var(--styled-text-h2-margin, 12px 0);
  padding:        var(--styled-text-h2-padding, 0 0 10px 0);
  font-size:      var(--styled-text-h2-font-size, 24px);
  line-height:    var(--styled-text-h2-line-height, 1.2);
  border-bottom:  var(--styled-text-h2-bottom-border, 1px solid #d0d7deb3);
}
.ui-styled-text > h3 {
  margin:         var(--styled-text-h3-margin, 12px 0);
  font-size:      var(--styled-text-h3-font-size, 20px);
  line-height:    var(--styled-text-h3-line-height, 1.2);
}
.ui-styled-text > h4 {
  font-size: 1.25rem;
  line-height: 1.2;
  margin-bottom: 1rem;
}

.ui-styled-text > p, 
.ui-styled-text > li {
  font-size: var(--styled-text-font-size, 16px);
}

.ui-styled-text blockquote {
  padding: var(--ui-styled-text-blockquote-padding);
  background-color: var(--ui-styled-text-blockquote-background);
  border-radius: var(--ui-styled-text-blockquote-border-radius);
}

.ui-styled-text code, 
.ui-styled-text pre code {
  line-height: 25px !important;
}
.ui-styled-text code {
  padding: 2px 4px;
}
.ui-styled-text pre code {
  display: block;
  padding: 12px;
  overflow: scroll;
}

.ui-styled-text code {
  background-color: var(--ui-styled-text-code-background);
  border-radius: var(--ui-styled-text-code-border-radius);
}
.ui-styled-text pre code {
  background-color: var(--ui-styled-text-code-background);
  border-radius: var(--ui-styled-text-code-border-radius);
}
.ui-styled-text > p code {
  white-space: nowrap;
}

.ui-styled-text code {
  background-color: var(--ui-styled-text-code-background);
  color: white;
  font-size: .85em;
}

.ui-styled-text > h3 code {
}

.ui-styled-text > p, 
.ui-styled-text code {
  margin-bottom: 1rem;
}
.ui-styled-text > ol li p,
.ui-styled-text > ul li p {
  margin-bottom: 0px;
}
.ui-styled-text > ol li, 
.ui-styled-text > ul li {
  margin-bottom: 3px;
}
.ui-styled-text > strong {
  font-weight: var(--bold-font-weight);
}
.ui-styled-text > ul, 
.ui-styled-text > ol > li > ul  {
  margin-bottom: 1rem;
  list-style-type: disc;
  margin-left: 20px;
}
.ui-styled-text > ol {
  margin-bottom: 1rem;
  list-style-type: decimal;
  margin-left: 20px;
}

.ui-styled-text > table {
  border-radius: var(--border-radius-1);
}
.ui-styled-text > table, 
.ui-styled-text > table tr {
  border-width: var(--border-width-default);
  border-color: var(--border-color-default);
}
.ui-styled-text > table th {
  text-align: left;
  padding-right: 10px;
  font-weight: var(--bold-font-weight);
}

.ui-styled-text p > a:not(.no-style),
.ui-styled-text li > a:not(.no-style) {
  color: var(--ui-styled-text-link-color);
  text-decoration: var(--ui-styled-text-link-text-decoration);
  text-decoration-thickness: var(--ui-styled-text-link-text-decoration-thickness);
}

.ui-styled-text > hr {
  margin: 20px 0;
}

/* Tooltips powered by https://kushagra.dev/lab/tooltip/ */

[class*=tooltip--] {
  position: relative;
}

[class*=tooltip--]:before, [class*=tooltip--]:after {
  position: absolute;
  transform: translate3d(0, 0, 0);
  visibility: hidden;
  opacity: 0;
  z-index: 1000000;
  pointer-events: none;
  transition: 0.3s ease;
  transition-delay: 0ms;
}
[class*=tooltip--]:hover:before, [class*=tooltip--]:hover:after {
  visibility: visible;
  opacity: 1;
}
[class*=tooltip--]:hover:before, [class*=tooltip--]:hover:after {
  transition-delay: 100ms;
}
[class*=tooltip--]:before {
  content: "";
  position: absolute;
  background: transparent;
  border: 6px solid transparent;
  background-color: var(--ui-tooltip-background-color);
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%);
  z-index: 1000001;
}
[class*=tooltip--]:after {
  background: var(--ui-tooltip-background-color);
  color: var(--ui-tooltip-text-color);
  padding: var(--ui-tooltip-padding);
  font-size: var(--ui-tooltip-font-size);
  line-height: 1rem;
  white-space: nowrap;
  border-radius: var(--ui-tooltip-border-radius);
  display: inline;
}
[class*=tooltip--][aria-label]:after {
  content: attr(aria-label);
}
[class*=tooltip--][data-tooltip]:after {
  content: attr(data-tooltip);
}

[aria-label=""]:before, [aria-label=""]:after,
[data-tooltip=""]:before,
[data-tooltip=""]:after {
  display: none !important;
}

.ui-tooltip--top {
  --rotation: 135deg;
}
.ui-tooltip--top:before {
  margin-bottom: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--top:before, .ui-tooltip--top:after {
  bottom: 100%;
  left: 50%;
}
.ui-tooltip--top:before {
  left: calc(50% - 6px);
}
.ui-tooltip--top:after {
  transform: translateX(-50%);
}
.ui-tooltip--top:hover:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--top:hover:after {
  transform: translateX(-50%) translateY(-8px);
}

/**
 * bottom tooltip
 */
.ui-tooltip--bottom {
  --rotation: -45deg;
}
.ui-tooltip--bottom:before {
  margin-top: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--bottom:before, .ui-tooltip--bottom:after {
  top: 100%;
  left: 50%;
}
.ui-tooltip--bottom:before {
  left: calc(50% - 6px);
}
.ui-tooltip--bottom:after {
  transform: translateX(-50%);
}
.ui-tooltip--bottom:hover:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--bottom:hover:after {
  transform: translateX(-50%) translateY(8px);
}

/**
 * right tooltip
 */
.ui-tooltip--right {
  --rotation: -135deg;
}
.ui-tooltip--right:before {
  margin-left: -5.5px;
  margin-bottom: -6px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--right:after {
  margin-bottom: calc(-1 * (1rem + 16px) / 2);
}
.ui-tooltip--right:before, .ui-tooltip--right:after {
  left: 100%;
  bottom: 50%;
}
.ui-tooltip--right:hover:before {
  transform: translateX(8px) rotate(var(--rotation));
}
.ui-tooltip--right:hover:after {
  transform: translateX(8px);
}

/**
 * left tooltip
 */
.ui-tooltip--left {
  --rotation: 45deg;
}
.ui-tooltip--left:before {
  margin-right: -5.5px;
  margin-bottom: -6px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--left:after {
  margin-bottom: calc(-1 * (1rem + 16px) / 2);
}
.ui-tooltip--left:before, .ui-tooltip--left:after {
  right: 100%;
  bottom: 50%;
}
.ui-tooltip--left:hover:before {
  transform: translateX(-8px) rotate(var(--rotation));
}
.ui-tooltip--left:hover:after {
  transform: translateX(-8px);
}

/**
 * top-left tooltip
 */
.ui-tooltip--top-left {
  --rotation: 135deg;
}
.ui-tooltip--top-left:before {
  margin-bottom: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--top-left:before, .ui-tooltip--top-left:after {
  bottom: 100%;
  left: 50%;
}
.ui-tooltip--top-left:before {
  left: calc(50% - 6px);
}
.ui-tooltip--top-left:after {
  transform: translateX(-100%);
}
.ui-tooltip--top-left:after {
  margin-left: 12px;
}
.ui-tooltip--top-left:hover:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--top-left:hover:after {
  transform: translateX(-100%) translateY(-8px);
}

/**
 * top-right tooltip
 */
.ui-tooltip--top-right {
  --rotation: 135deg;
}
.ui-tooltip--top-right:before {
  margin-bottom: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--top-right:before, .ui-tooltip--top-right:after {
  bottom: 100%;
  left: 50%;
}
.ui-tooltip--top-right:before {
  left: calc(50% - 6px);
}
.ui-tooltip--top-right:after {
  transform: translateX(0);
}
.ui-tooltip--top-right:after {
  margin-left: -12px;
}
.ui-tooltip--top-right:hover:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--top-right:hover:after {
  transform: translateY(-8px);
}

/**
 * bottom-left tooltip
 */
.ui-tooltip--bottom-left {
  --rotation: -45deg;
}
.ui-tooltip--bottom-left:before {
  margin-top: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--bottom-left:before, .ui-tooltip--bottom-left:after {
  top: 100%;
  left: 50%;
}
.ui-tooltip--bottom-left:before {
  left: calc(50% - 6px);
}
.ui-tooltip--bottom-left:after {
  transform: translateX(-100%);
}
.ui-tooltip--bottom-left:after {
  margin-left: 12px;
}
.ui-tooltip--bottom-left:hover:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--bottom-left:hover:after {
  transform: translateX(-100%) translateY(8px);
}

/**
 * bottom-right tooltip
 */
.ui-tooltip--bottom-right {
  --rotation: -45deg;
}
.ui-tooltip--bottom-right:before {
  margin-top: -5.5px;
  transform: rotate(var(--rotation));
}
.ui-tooltip--bottom-right:before, .ui-tooltip--bottom-right:after {
  top: 100%;
  left: 50%;
}
.ui-tooltip--bottom-right:before {
  left: calc(50% - 6px);
}
.ui-tooltip--bottom-right:after {
  transform: translateX(0);
}
.ui-tooltip--bottom-right:after {
  margin-left: -12px;
}
.ui-tooltip--bottom-right:hover:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--bottom-right:hover:after {
  transform: translateY(8px);
}

.ui-tooltip--small:after,
.ui-tooltip--medium:after,
.ui-tooltip--large:after,
.ui-tooltip--fit:after {
  box-sizing: border-box;
  white-space: normal;
  line-height: 1.4em;
  word-wrap: break-word;
}

.ui-tooltip--small:after {
  width: 80px;
}

.ui-tooltip--medium:after {
  width: 150px;
}

.ui-tooltip--large:after {
  width: 300px;
}

.ui-tooltip--fit:after {
  width: 100%;
}

[class*=tooltip--]:after {
  box-shadow: var(--ui-tooltip-box-shadow);
}

.ui-tooltip--error:after {
  background-color: hsl(1, 40%, 50%);
  text-shadow: 0 1px 0px #592726;
}
.ui-tooltip--error:before {
  background-color: hsl(1, 40%, 50%);
}

.ui-tooltip--warning:after {
  background-color: hsl(38, 46%, 54%);
  text-shadow: 0 1px 0px #6c5328;
}
.ui-tooltip--warning:before {
  background-color: hsl(38, 46%, 54%);
}

.ui-tooltip--info:after {
  background-color: hsl(200, 50%, 45%);
  text-shadow: 0 1px 0px #1a3c4d;
}
.ui-tooltip--info:before {
  background-color: hsl(200, 50%, 45%);
}

.ui-tooltip--success:after {
  background-color: hsl(121, 32%, 40%);
  text-shadow: 0 1px 0px #1a321a;
}
.ui-tooltip--success:before {
  background-color: hsl(121, 32%, 40%);
}

.ui-tooltip--always:after, .ui-tooltip--always:before {
  opacity: 1;
  visibility: visible;
}
.ui-tooltip--always.ui-tooltip--top:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--top:after {
  transform: translateX(-50%) translateY(-8px);
}
.ui-tooltip--always.ui-tooltip--top-left:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--top-left:after {
  transform: translateX(-100%) translateY(-8px);
}
.ui-tooltip--always.ui-tooltip--top-right:before {
  transform: translateY(-8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--top-right:after {
  transform: translateY(-8px);
}
.ui-tooltip--always.ui-tooltip--bottom:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--bottom:after {
  transform: translateX(-50%) translateY(8px);
}
.ui-tooltip--always.ui-tooltip--bottom-left:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--bottom-left:after {
  transform: translateX(-100%) translateY(8px);
}
.ui-tooltip--always.ui-tooltip--bottom-right:before {
  transform: translateY(8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--bottom-right:after {
  transform: translateY(8px);
}
.ui-tooltip--always.ui-tooltip--left:before {
  transform: translateX(-8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--left:after {
  transform: translateX(-8px);
}
.ui-tooltip--always.ui-tooltip--right:before {
  transform: translateX(8px) rotate(var(--rotation));
}
.ui-tooltip--always.ui-tooltip--right:after {
  transform: translateX(8px);
}

.ui-tooltip--rounded:before {
  border-radius: 0 4px 0 0;
}
.ui-tooltip--rounded:after {
  border-radius: 4px;
}

.ui-tooltip--no-animate:before, .ui-tooltip--no-animate:after {
  transition-duration: 0ms;
}

.ui-tooltip--bounce:before, .ui-tooltip--bounce:after {
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s cubic-bezier(0.71, 1.7, 0.77, 1.24);
}

@supports (transition-timing-function: linear(0, 1)) {
  .ui-tooltip--bounce:before, .ui-tooltip--bounce:after {
    --spring-easing: linear(
    	0,
    	0.009,
    	0.035 2.1%,
    	0.141 4.4%,
    	0.723 12.9%,
    	0.938,
    	1.077 20.4%,
    	1.121,
    	1.149 24.3%,
    	1.159,
    	1.163 27%,
    	1.154,
    	1.129 32.8%,
    	1.051 39.6%,
    	1.017 43.1%,
    	0.991,
    	0.977 51%,
    	0.975 57.1%,
    	0.997 69.8%,
    	1.003 76.9%,
    	1
    );
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.5s var(--spring-easing);
  }
}
.ui-tooltip--no-shadow:before, .ui-tooltip--no-shadow:after {
  text-shadow: initial;
  box-shadow: initial;
}
.ui-tooltip--no-arrow:before {
  display: none;
}

.ui-toggle {
  position: relative;
  display: inline-block;
  width:  calc( (var(--ui-toggle-width) * 2) + (2 * var(--ui-toggle-padding)));
  height: calc( var(--ui-toggle-width) + (2 * var(--ui-toggle-padding)));
  .--slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--ui-toggle-background-inactive);
    -webkit-transition: .4s;
    transition: .4s;
    border-radius: 34px;
    &:hover {
      background-color: var(--ui-toggle-background-hover);
    }
  }
  .--slider:before {
    position: absolute;
    content: "";
    height: var(--ui-toggle-width);
    width: var(--ui-toggle-width);
    left: var(--ui-toggle-padding);
    bottom: var(--ui-toggle-padding);
    background-color: white;
    -webkit-transition: .4s;
    transition: .4s;
    border-radius: 50%;
  }
  input {
    opacity: 0;
    width: 0;
    height: 0;
  }
  input:checked + .--slider {
    background-color: var(--ui-toggle-background-active);
  }
  input:checked + .--slider:before {
    transform: translateX(var(--ui-toggle-width));
  }
}

.ui-body {
  height: 100%;
}

.ui-container {
  margin: var(--ui-container-margin);
  max-width: var(--ui-container-max-width);
  padding: 0 var(--ui-container-padding);
  &.--xs {
    max-width: var(--ui-container-max-width-xs);
  }
  &.--sm {
    max-width: var(--ui-container-max-width-sm);
  }
  &.--md {
    max-width: var(--ui-container-max-width-md);
  }
  &.--lg {
    max-width: var(--ui-container-max-width-lg);
  }
  &.--xl {
    max-width: var(--ui-container-max-width-xl);
  }
  &.--2xl {
    max-width: var(--ui-container-max-width-2xl);
  }
}

.ui-modal {
  position: relative;
  z-index: 10;
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  &.--visible {
    transition: opacity 0.3s ease;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    .--overlay {
      visibility: visible;
    }
    .--dialog {
      transform: translateY(0);
    }
  }
  .--overlay {
    background-color: var(--ui-modal-overlay-color);
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    visibility: hidden;
    transition: opacity 0.3s ease;
  }
  .--wrapper-outer {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 10;
    width: 100vw; 
    overflow-y: scroll;
  }
  .--wrapper-inner {
    display: flex ;
    min-height: 100vh;
    align-items: center;
    justify-content: center;
    padding: 1rem;
    text-align: center;
  }
  .--dialog {
    position: relative;
    overflow: hidden;
    border-radius: var(--ui-modal-border-radius);
    background-color: var(--ui-modal-background-color);
    padding: var(--ui-modal-padding);
    width: 100vw;
    max-width: 600px;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    transform: translateY(100%);
    text-align: left;
    max-height: 600px;
    overflow-y: scroll;
    &.--xs {
      max-width: var(--ui-modal-max-width-xs);
    }
    &.--sm {
      max-width: var(--ui-modal-max-width-sm);
    }
    &.--lg {
      max-width: var(--ui-modal-max-width-lg);
    }
    &.--xl {
      max-width: var(--ui-modal-max-width-xl);
    }
    &.--2xl {
      max-width: var(--ui-modal-max-width-2xl);
    }
    & .--modal-top-section,
    & .--modal-bottom-section {
      display: flex;
      padding: var(--ui-modal-padding);
      margin-left: calc(-1 * var(--ui-modal-padding));
      margin-right: calc(-1 * var(--ui-modal-padding));
      justify-content: space-between;
    }
    & .--modal-top-section {
      border-bottom: var(--ui-box-separator-border);
      margin-bottom: var(--ui-modal-padding);
      margin-top: calc(-1 * var(--ui-modal-padding));
    }
    & .--modal-bottom-section {
      border-top: var(--ui-box-separator-border);
      margin-top: var(--ui-modal-padding);
      margin-bottom: calc(-1 * var(--ui-modal-padding));
    }
  }
}

.ui-shimmer {
  width: 100%
}
.ui-shimmer > * {
  margin: var(--shimmer-block-default-margin, 0 0 10px 0);
}
.ui-shimmer .--circle,
.ui-shimmer .--rect {
  background: var(--shimmer-block-color-from, #f6f7f8);
  background-image: linear-gradient(to right, var(--shimmer-block-color-from, #f6f7f8) 0%, var(--color-to, #edeef1) 20%, var(--shimmer-block-color-from, #f6f7f8) 40%, var(--shimmer-block-color-to, #f6f7f8) 100%);
  background-repeat: repeat-y;
  background-size: 100% 50px;
  position: relative;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  animation-iteration-count: infinite;
  animation-name: placeholderShimmer;
  animation-timing-function: linear;
}
.ui-shimmer .--rect {
  height: var(--shimmer-block-height, 20px);
  border-radius: var(--shimmer-block-border-radius, 10px)
}
.ui-shimmer .--circle {
  border-radius: 100000px;
  width: calc( var(--shimmer-block-height, 20px) * 3);
  height: calc( var(--shimmer-block-height, 20px) * 3);
  animation-duration: .8s;
  animation-name: placeholderShimmerCircle;
}
.ui-shimmer .--circle.--xs {
  width: var(--shimmer-block-height, 20px); 
  height: var(--shimmer-block-height, 20px); 
}
.ui-shimmer .--circle.--sm {
  width: calc( var(--shimmer-block-height, 20px) * 2);
  height: calc( var(--shimmer-block-height, 20px) * 2);
}
.ui-shimmer .--circle.--md {
  width: calc( var(--shimmer-block-height, 20px) * 4);
  height: calc( var(--shimmer-block-height, 20px) * 4);
}
.ui-shimmer .--circle.--g {
  width: calc( var(--shimmer-block-height, 20px) * 5);
  height: calc( var(--shimmer-block-height, 20px) * 5);
}
.ui-shimmer .--centered {
  margin-left: auto;
  margin-right: auto;
} 
.ui-shimmer .--width-\.25 {
  width: 25%;
}
.ui-shimmer .--width-\.5 {
  width: 50%;
}
.ui-shimmer .--width-\.75 {
  width: 75%;
}

@keyframes placeholderShimmer {
  0% {
    background-position: -468px 0;
  }
  100% {
    background-position: 468px 0;
  }
}

@keyframes placeholderShimmerCircle {
  0% {
    background-position: -80px 0;
  }
  100% {
    background-position: 80px 0;
  }
}

@keyframes fade-in {
  from { opacity: 0; }
}

@keyframes fade-out {
  to { opacity: 0; }
}

@keyframes slide-from-right {
  from { transform: translateX(90px); }
}

@keyframes slide-to-left {
  to { transform: translateX(-90px); }
}

::view-transition-old(slide-from-right) {
  animation: 180ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
  600ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-left;
}
::view-transition-new(slide-from-right) {
  animation: 420ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in,
  600ms cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
}

.ui-view-transition {
  &.--slide-from-right {
    view-transition-name: slide-from-right;
  }
}
