.fa-solid,
.fa-regular,
.fa-brands,
.fa-classic,
.fas,
.far,
.fab,
.fal,
.fat,
.fad,
.fadr,
.fadl,
.fadt,
.fass,
.fasr,
.fasl,
.fast,
.fasds,
.fasdr,
.fasdl,
.fasdt,
.faslr,
.faslpr,
.fawsb,
.fatl,
.fans,
.fands,
.faes,
.fajr,
.fajfr,
.fajdr,
.facr,
.fa-solid,
.fa-semibold,
.fa-regular,
.fa-light,
.fa-thin,
.fa-brands,
.fa-classic,
.fa-duotone,
.fa-sharp,
.fa-sharp-duotone,
.fa-chisel,
.fa-etch,
.fa-jelly,
.fa-jelly-duo,
.fa-jelly-fill,
.fa-notdog,
.fa-notdog-duo,
.fa-slab,
.fa-slab-press,
.fa-thumbprint,
.fa-whiteboard,
.fa {
  --_fa-family: var(--fa-family, var(--fa-style-family, "Font Awesome 7 Pro"));
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: var(--fa-display, inline-block);
  font-family: var(--_fa-family);
  font-feature-settings: normal;
  font-style: normal;
  font-synthesis: none;
  font-variant: normal;
  font-weight: var(--fa-style, 900);
  line-height: 1;
  text-align: center;
  text-rendering: auto;
  width: var(--fa-width, 1.25em);
}

:is(.fas,
.fass,
.far,
.fasr,
.fal,
.fasl,
.fat,
.fast,
.fad,
.fadr,
.fadl,
.fadt,
.fasds,
.fasdr,
.fasdl,
.fasdt,
.fab,
.faslr,
.faslpr,
.fawsb,
.fatl,
.fans,
.fands,
.faes,
.fajr,
.fajfr,
.fajdr,
.facr,
.fa-solid,
.fa-semibold,
.fa-regular,
.fa-light,
.fa-thin,
.fa-brands,
.fa-classic,
.fa-duotone,
.fa-sharp,
.fa-sharp-duotone,
.fa-chisel,
.fa-etch,
.fa-jelly,
.fa-jelly-duo,
.fa-jelly-fill,
.fa-notdog,
.fa-notdog-duo,
.fa-slab,
.fa-slab-press,
.fa-thumbprint,
.fa-whiteboard,
.fa)::before {
  content: var(--fa);
  content: var(--fa)/"";
}

:is(.fad,
.fa-duotone,
.fadr,
.fadl,
.fadt,
.fasds,
.fa-sharp-duotone,
.fasdr,
.fasdl,
.fasdt,
.fatl,
.fa-thumbprint,
.fands,
.fa-notdog-duo,
.fajdr,
.fa-jelly-duo)::after {
  content: var(--fa);
  content: var(--fa)/"";
  font-feature-settings: "ss01";
}

.fa-1x {
  font-size: 1em;
}

.fa-2x {
  font-size: 2em;
}

.fa-3x {
  font-size: 3em;
}

.fa-4x {
  font-size: 4em;
}

.fa-5x {
  font-size: 5em;
}

.fa-6x {
  font-size: 6em;
}

.fa-7x {
  font-size: 7em;
}

.fa-8x {
  font-size: 8em;
}

.fa-9x {
  font-size: 9em;
}

.fa-10x {
  font-size: 10em;
}

.fa-2xs {
  font-size: calc(10 / 16 * 1em); /* converts a 10px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 10 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 10 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-xs {
  font-size: calc(12 / 16 * 1em); /* converts a 12px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 12 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 12 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-sm {
  font-size: calc(14 / 16 * 1em); /* converts a 14px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 14 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 14 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-lg {
  font-size: calc(20 / 16 * 1em); /* converts a 20px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 20 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 20 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-xl {
  font-size: calc(24 / 16 * 1em); /* converts a 24px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 24 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 24 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-2xl {
  font-size: calc(32 / 16 * 1em); /* converts a 32px size into an em-based value that's relative to the scale's 16px base */
  line-height: calc(1 / 32 * 1em); /* sets the line-height of the icon back to that of it's parent */
  vertical-align: calc((6 / 32 - 0.375) * 1em); /* vertically centers the icon taking into account the surrounding text's descender */
}

.fa-width-auto {
  --fa-width: auto;
}

.fa-fw,
.fa-width-fixed {
  --fa-width: 1.25em;
}

.fa-ul {
  list-style-type: none;
  margin-inline-start: var(--fa-li-margin, 2.5em);
  padding-inline-start: 0;
}
.fa-ul > li {
  position: relative;
}

.fa-li {
  inset-inline-start: calc(-1 * var(--fa-li-width, 2em));
  position: absolute;
  text-align: center;
  width: var(--fa-li-width, 2em);
  line-height: inherit;
}

/* Heads Up: Bordered Icons will not be supported in the future!
  - This feature will be deprecated in the next major release of Font Awesome (v8)!
  - You may continue to use it in this version *v7), but it will not be supported in Font Awesome v8.
*/
/* Notes:
* --@{v.$css-prefix}-border-width = 1/16 by default (to render as ~1px based on a 16px default font-size)
* --@{v.$css-prefix}-border-padding =
  ** 3/16 for vertical padding (to give ~2px of vertical whitespace around an icon considering it's vertical alignment)
  ** 4/16 for horizontal padding (to give ~4px of horizontal whitespace around an icon)
*/
.fa-border {
  border-color: var(--fa-border-color, #eee);
  border-radius: var(--fa-border-radius, 0.1em);
  border-style: var(--fa-border-style, solid);
  border-width: var(--fa-border-width, 0.0625em);
  box-sizing: var(--fa-border-box-sizing, content-box);
  padding: var(--fa-border-padding, 0.1875em 0.25em);
}

.fa-pull-left,
.fa-pull-start {
  float: inline-start;
  margin-inline-end: var(--fa-pull-margin, 0.3em);
}

.fa-pull-right,
.fa-pull-end {
  float: inline-end;
  margin-inline-start: var(--fa-pull-margin, 0.3em);
}

.fa-beat {
  animation-name: fa-beat;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, ease-in-out);
}

.fa-bounce {
  animation-name: fa-bounce;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.28, 0.84, 0.42, 1));
}

.fa-fade {
  animation-name: fa-fade;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));
}

.fa-beat-fade {
  animation-name: fa-beat-fade;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, cubic-bezier(0.4, 0, 0.6, 1));
}

.fa-flip {
  animation-name: fa-flip;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, ease-in-out);
}

.fa-shake {
  animation-name: fa-shake;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, linear);
}

.fa-spin {
  animation-name: fa-spin;
  animation-delay: var(--fa-animation-delay, 0s);
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 2s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, linear);
}

.fa-spin-reverse {
  --fa-animation-direction: reverse;
}

.fa-pulse,
.fa-spin-pulse {
  animation-name: fa-spin;
  animation-direction: var(--fa-animation-direction, normal);
  animation-duration: var(--fa-animation-duration, 1s);
  animation-iteration-count: var(--fa-animation-iteration-count, infinite);
  animation-timing-function: var(--fa-animation-timing, steps(8));
}

@media (prefers-reduced-motion: reduce) {
  .fa-beat,
  .fa-bounce,
  .fa-fade,
  .fa-beat-fade,
  .fa-flip,
  .fa-pulse,
  .fa-shake,
  .fa-spin,
  .fa-spin-pulse {
    animation: none !important;
    transition: none !important;
  }
}
@keyframes fa-beat {
  0%, 90% {
    transform: scale(1);
  }
  45% {
    transform: scale(var(--fa-beat-scale, 1.25));
  }
}
@keyframes fa-bounce {
  0% {
    transform: scale(1, 1) translateY(0);
  }
  10% {
    transform: scale(var(--fa-bounce-start-scale-x, 1.1), var(--fa-bounce-start-scale-y, 0.9)) translateY(0);
  }
  30% {
    transform: scale(var(--fa-bounce-jump-scale-x, 0.9), var(--fa-bounce-jump-scale-y, 1.1)) translateY(var(--fa-bounce-height, -0.5em));
  }
  50% {
    transform: scale(var(--fa-bounce-land-scale-x, 1.05), var(--fa-bounce-land-scale-y, 0.95)) translateY(0);
  }
  57% {
    transform: scale(1, 1) translateY(var(--fa-bounce-rebound, -0.125em));
  }
  64% {
    transform: scale(1, 1) translateY(0);
  }
  100% {
    transform: scale(1, 1) translateY(0);
  }
}
@keyframes fa-fade {
  50% {
    opacity: var(--fa-fade-opacity, 0.4);
  }
}
@keyframes fa-beat-fade {
  0%, 100% {
    opacity: var(--fa-beat-fade-opacity, 0.4);
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(var(--fa-beat-fade-scale, 1.125));
  }
}
@keyframes fa-flip {
  50% {
    transform: rotate3d(var(--fa-flip-x, 0), var(--fa-flip-y, 1), var(--fa-flip-z, 0), var(--fa-flip-angle, -180deg));
  }
}
@keyframes fa-shake {
  0% {
    transform: rotate(-15deg);
  }
  4% {
    transform: rotate(15deg);
  }
  8%, 24% {
    transform: rotate(-18deg);
  }
  12%, 28% {
    transform: rotate(18deg);
  }
  16% {
    transform: rotate(-22deg);
  }
  20% {
    transform: rotate(22deg);
  }
  32% {
    transform: rotate(-12deg);
  }
  36% {
    transform: rotate(12deg);
  }
  40%, 100% {
    transform: rotate(0deg);
  }
}
@keyframes fa-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.fa-rotate-90 {
  transform: rotate(90deg);
}

.fa-rotate-180 {
  transform: rotate(180deg);
}

.fa-rotate-270 {
  transform: rotate(270deg);
}

.fa-flip-horizontal {
  transform: scale(-1, 1);
}

.fa-flip-vertical {
  transform: scale(1, -1);
}

.fa-flip-both,
.fa-flip-horizontal.fa-flip-vertical {
  transform: scale(-1, -1);
}

.fa-rotate-by {
  transform: rotate(var(--fa-rotate-angle, 0));
}

.fa-stack {
  display: inline-block;
  height: 2em;
  line-height: 2em;
  position: relative;
  vertical-align: middle;
  width: 2.5em;
}

.fa-stack-1x,
.fa-stack-2x {
  left: 0;
  position: absolute;
  text-align: center;
  width: 100%;
  z-index: var(--fa-stack-z-index, auto);
}

.fa-stack-1x {
  line-height: inherit;
}

.fa-stack-2x {
  font-size: 2em;
}

.fa-inverse {
  color: var(--fa-inverse, #fff);
}

/* Font Awesome uses the Unicode Private Use Area (PUA) to ensure screen
   readers do not read off random characters that represent icons */
.fa-add { --fa: "\2b"; }
.fa-angle-double-up { --fa: "\f102"; }
.fa-angle-down { --fa: "\f107"; }
.fa-angle-up { --fa: "\f106"; }
.fa-angles-up { --fa: "\f102"; }
.fa-arrow-up { --fa: "\f062"; }
.fa-arrow-up-right-from-square { --fa: "\f08e"; }
.fa-arrows { --fa: "\f047"; }
.fa-arrows-h { --fa: "\f07e"; }
.fa-arrows-left-right { --fa: "\f07e"; }
.fa-arrows-rotate { --fa: "\f021"; }
.fa-arrows-up-down-left-right { --fa: "\f047"; }
.fa-award { --fa: "\f559"; }
.fa-backpack { --fa: "\f5d4"; }
.fa-bars { --fa: "\f0c9"; }
.fa-block-question { --fa: "\e3dd"; }
.fa-bolt { --fa: "\f0e7"; }
.fa-caret-up { --fa: "\f0d8"; }
.fa-cart-shopping { --fa: "\f07a"; }
.fa-check { --fa: "\f00c"; }
.fa-chess-rook { --fa: "\f447"; }
.fa-circle-info { --fa: "\f05a"; }
.fa-clock-rotate-left { --fa: "\f1da"; }
.fa-cog { --fa: "\f013"; }
.fa-coins { --fa: "\f51e"; }
.fa-comment-dots { --fa: "\f4ad"; }
.fa-commenting { --fa: "\f4ad"; }
.fa-compress { --fa: "\f066"; }
.fa-cookie { --fa: "\f563"; }
.fa-copy { --fa: "\f0c5"; }
.fa-crosshairs { --fa: "\f05b"; }
.fa-crown { --fa: "\f521"; }
.fa-cube { --fa: "\f1b2"; }
.fa-cubes { --fa: "\f1b3"; }
.fa-cut { --fa: "\f0c4"; }
.fa-dice { --fa: "\f522"; }
.fa-dizzy { --fa: "\f567"; }
.fa-door-closed { --fa: "\f52a"; }
.fa-door-open { --fa: "\f52b"; }
.fa-download { --fa: "\f019"; }
.fa-ellipsis { --fa: "\f141"; }
.fa-ellipsis-h { --fa: "\f141"; }
.fa-exclamation { --fa: "\21"; }
.fa-expand { --fa: "\f065"; }
.fa-external-link { --fa: "\f08e"; }
.fa-eye { --fa: "\f06e"; }
.fa-eye-slash { --fa: "\f070"; }
.fa-face-dizzy { --fa: "\f567"; }
.fa-face-smile { --fa: "\f118"; }
.fa-feather-alt { --fa: "\f56b"; }
.fa-feather-pointed { --fa: "\f56b"; }
.fa-file-alt { --fa: "\f15c"; }
.fa-file-clipboard { --fa: "\f0ea"; }
.fa-file-lines { --fa: "\f15c"; }
.fa-file-text { --fa: "\f15c"; }
.fa-film { --fa: "\f008"; }
.fa-film-alt { --fa: "\f008"; }
.fa-film-simple { --fa: "\f008"; }
.fa-fire { --fa: "\f06d"; }
.fa-fist-raised { --fa: "\f6de"; }
.fa-flag { --fa: "\f024"; }
.fa-folder-image { --fa: "\e18a"; }
.fa-gauge-high { --fa: "\f625"; }
.fa-gear { --fa: "\f013"; }
.fa-gem { --fa: "\f3a5"; }
.fa-globe { --fa: "\f0ac"; }
.fa-hammer { --fa: "\f6e3"; }
.fa-hand-fist { --fa: "\f6de"; }
.fa-hand-holding-medical { --fa: "\e05c"; }
.fa-hand-point-left { --fa: "\f0a5"; }
.fa-hat-santa { --fa: "\f7a7"; }
.fa-heart { --fa: "\f004"; }
.fa-heart-music-camera-bolt { --fa: "\f86d"; }
.fa-history { --fa: "\f1da"; }
.fa-icons { --fa: "\f86d"; }
.fa-info-circle { --fa: "\f05a"; }
.fa-joystick { --fa: "\f8c5"; }
.fa-layer-group { --fa: "\f5fd"; }
.fa-lightbulb { --fa: "\f0eb"; }
.fa-list { --fa: "\f03a"; }
.fa-list-squares { --fa: "\f03a"; }
.fa-location-check { --fa: "\f606"; }
.fa-location-xmark { --fa: "\f60e"; }
.fa-lock { --fa: "\f023"; }
.fa-lock-open { --fa: "\f3c1"; }
.fa-magnifying-glass { --fa: "\f002"; }
.fa-map-marker-check { --fa: "\f606"; }
.fa-map-marker-times { --fa: "\f60e"; }
.fa-map-marker-xmark { --fa: "\f60e"; }
.fa-minus-square { --fa: "\f146"; }
.fa-music { --fa: "\f001"; }
.fa-navicon { --fa: "\f0c9"; }
.fa-palette { --fa: "\f53f"; }
.fa-pants { --fa: "\e6d5"; }
.fa-paste { --fa: "\f0ea"; }
.fa-pen { --fa: "\f304"; }
.fa-pen-field { --fa: "\e211"; }
.fa-person-arrow-down-to-line { --fa: "\e538"; }
.fa-person-arrow-up-from-line { --fa: "\e539"; }
.fa-person-falling-burst { --fa: "\e547"; }
.fa-person-military-pointing { --fa: "\e54a"; }
.fa-planet-ringed { --fa: "\e020"; }
.fa-plus { --fa: "\2b"; }
.fa-power-off { --fa: "\f011"; }
.fa-recycle { --fa: "\f1b8"; }
.fa-redo-alt { --fa: "\f2f9"; }
.fa-refresh { --fa: "\f021"; }
.fa-right-from-bracket { --fa: "\f2f5"; }
.fa-rocket-launch { --fa: "\e027"; }
.fa-rotate-forward { --fa: "\f2f9"; }
.fa-rotate-right { --fa: "\f2f9"; }
.fa-scissors { --fa: "\f0c4"; }
.fa-search { --fa: "\f002"; }
.fa-shield { --fa: "\f132"; }
.fa-shield-alt { --fa: "\f3ed"; }
.fa-shield-blank { --fa: "\f132"; }
.fa-shield-halved { --fa: "\f3ed"; }
.fa-shirt { --fa: "\f553"; }
.fa-shopping-cart { --fa: "\f07a"; }
.fa-sign-out-alt { --fa: "\f2f5"; }
.fa-smile { --fa: "\f118"; }
.fa-snowflake { --fa: "\f2dc"; }
.fa-square-dashed { --fa: "\e269"; }
.fa-square-minus { --fa: "\f146"; }
.fa-star { --fa: "\f005"; }
.fa-sync { --fa: "\f021"; }
.fa-t-shirt { --fa: "\f553"; }
.fa-tachometer-alt { --fa: "\f625"; }
.fa-tachometer-alt-fast { --fa: "\f625"; }
.fa-terminal { --fa: "\f120"; }
.fa-trophy { --fa: "\f091"; }
.fa-tshirt { --fa: "\f553"; }
.fa-up-from-bracket { --fa: "\e590"; }
.fa-upload { --fa: "\f093"; }
.fa-user { --fa: "\f007"; }
.fa-user-alt { --fa: "\f007"; }
.fa-user-alt-slash { --fa: "\f506"; }
.fa-user-friends { --fa: "\f500"; }
.fa-user-group { --fa: "\f500"; }
.fa-user-group-crown { --fa: "\f6a5"; }
.fa-user-large { --fa: "\f007"; }
.fa-user-large-slash { --fa: "\f506"; }
.fa-user-minus { --fa: "\f503"; }
.fa-user-plus { --fa: "\f234"; }
.fa-user-slash { --fa: "\f506"; }
.fa-user-unlock { --fa: "\e058"; }
.fa-users-crown { --fa: "\f6a5"; }
.fa-video { --fa: "\f03d"; }
.fa-video-camera { --fa: "\f03d"; }
.fa-volume { --fa: "\f6a8"; }
.fa-volume-down { --fa: "\f027"; }
.fa-volume-low { --fa: "\f027"; }
.fa-volume-medium { --fa: "\f6a8"; }
.fa-volume-slash { --fa: "\f2e2"; }
.fa-wrench { --fa: "\f0ad"; }
.fa-x { --fa: "\58"; }
.fa-zap { --fa: "\f0e7"; }
