/**!
  Visualization Classes for debugging the vertical-collection
  */
.vertical-collection-visual-debugger {
  height: 100%;
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: left;
  background: rgba(50, 50, 50, 1);
  width: 125px;
}

.vertical-collection-visual-debugger .vc_visualization-container {
  transform: scale(0.25);
  left: 0;
  position: relative;
}


.vertical-collection-visual-debugger .vc_visualization-screen {
  position: absolute;
  background: transparent;
  box-sizing: content-box;
  border-top: 2px dashed yellow;
  border-bottom: 2px dashed yellow;
  width: 500px;
}

.vertical-collection-visual-debugger .vc_visualization-scroll-container {
  position: absolute;
  width: 500px;
  background: rgba(100, 230, 100, 0.65);
}

.vertical-collection-visual-debugger .vc_visualization-item-container {
  position: absolute;
  width: 500px;
  background: rgba(255, 255, 255, .15);
}

.vertical-collection-visual-debugger .vc_visualization-virtual-component {
  box-sizing: border-box;
  background: rgba(230, 100, 230, 0.6);
  border: 1px dotted #bbb;
  border-top: 0px;
  color: #fff;
  text-align: center;
  font-size: 2.5em;
  width: 250px;
}

.vertical-collection-visual-debugger .vc_visualization-virtual-component:first-of-type {
  border-top: 1px dotted #bbb;
}

.vertical-collection-visual-debugger .vc_visualization-virtual-component.culled {
  background: transparent;
}

.x-toggle {
  display: none;
}

.x-toggle,
.x-toggle::after,
.x-toggle::before,
.x-toggle *,
.x-toggle *::after,
.x-toggle *::before,
.x-toggle + label > .x-toggle-btn {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.x-toggle::-moz-selection,
.x-toggle::after::-moz-selection,
.x-toggle::before::-moz-selection,
.x-toggle *::-moz-selection,
.x-toggle *::after::-moz-selection,
.x-toggle *::before::-moz-selection,
.x-toggle + label > .x-toggle-btn::-moz-selection {
  background: none;
}

.x-toggle::selection,
.x-toggle::after::selection,
.x-toggle::before::selection,
.x-toggle *::selection,
.x-toggle *::after::selection,
.x-toggle *::before::selection,
.x-toggle + label > .x-toggle-btn::selection {
  background: none;
}

label > .x-toggle-btn.x-toggle-disabled {
  cursor: not-allowed;
}

label > .x-toggle-btn {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  outline: 0;
  display: flex;
  flex-basis: 4em;
  height: 2em;
  position: relative;
  cursor: pointer;
}

label > .x-toggle-btn::after,
label > .x-toggle-btn::before {
  position: relative;
  display: block;
  content: "";
  width: 50%;
  height: 100%;
}

label > .x-toggle-btn::after {
  left: 0;
}

label > .x-toggle-btn::before {
  display: none;
}

.x-toggle:checked + label > .x-toggle-btn::after {
  left: 50%;
}

.x-toggle-component {
  display: flex;
  justify-content: center;
  align-items: center;
  outline: none;
}

.x-toggle-component.x-toggle-focused .x-toggle-btn:not(.x-toggle-disabled)::after,
.x-toggle-component.x-toggle-focused .x-toggle-btn:not(.x-toggle-disabled)::before {
  -webkit-box-shadow: 0 0 3px 2px #0099e0;
  -moz-box-shadow: 0 0 3px 2px #0099e0;
  box-shadow: 0 0 2px 3px #0099e0;
}

.x-toggle-container {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  height: auto;
  padding: 0 0.35rem;
}

.x-toggle-component .toggle-text {
  display: flex;
  cursor: pointer;
}

.x-toggle-container.small {
  width: 2.75rem;
  font-size: 1rem;
  padding: 0 0.25rem;
}

.x-toggle-container.medium {
  width: 3.75rem;
  font-size: 1rem;
}

.x-toggle-container.large {
  width: 5.7rem;
  font-size: 1.2rem;
  padding: 0 0.5rem;
}

.x-toggle-container label {
  min-width: 100%;
  max-width: 100%;
}

.x-toggle-container .toggle-text.toggle-prefix {
  padding-right: 0.25rem;
}

.x-toggle-container .toggle-text.toggle-postfix {
  padding-left: 0.25rem;
}

.x-toggle-component label.off-label {
  padding-right: 0.5rem;
}

.x-toggle-component label.on-label {
  padding-left: 0.5rem;
}

label > .x-toggle-default.x-toggle-btn {
  padding: 0.16em 0.1em;
  background-color: #e7e7e7;
  border-radius: 0.2em;
  transition: background-color 0.2s;
}

.x-toggle:checked + label > .x-toggle-default.x-toggle-btn {
  background-color: #797979;
}

label > .x-toggle-default.x-toggle-btn::after {
  background-color: #fff;
  transition: left 0.2s;
  border-radius: 0.2em;
}

label > .x-toggle-default.small {
  width: 3em;
  height: 1.6em;
}

label > .x-toggle-default.medium {
  width: 4em;
  height: 2.1em;
  padding: 3px;
}

label > .x-toggle-default.large {
  width: 4.7em;
  height: 2.1em;
  padding: 4px;
}

/* Dark theme variables */
:root{
  --ios-track-dark: #2121218f;
  --ios-border-dark: 1px solid #646464;
  --ios-thumb-checked-dark: #86d993;
}

/* Default theme */
.x-toggle-ios.x-toggle-btn {
  background: #fbfbfb;
  border-radius: 2em;
  padding: 2px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  border: 1px solid #e8eae9;
}

.x-toggle-ios.x-toggle-btn::after {
  border-radius: 2em;
  background: #fbfbfb;
  -webkit-transition: left 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), padding 0.3s ease, margin 0.3s ease;
  transition: left 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), padding 0.3s ease, margin 0.3s ease;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.1), 0 4px 0 rgba(0, 0, 0, 0.08);
}

.x-toggle-ios.x-toggle-btn:active {
  box-shadow: inset 0 0 0 2em #e8eae9;
}

.x-toggle-ios.x-toggle-btn:active::after {
  padding-right: 0.8em;
}

.x-toggle:checked + label > .x-toggle-ios.x-toggle-btn {
  background: #54d159;
}

.x-toggle:checked + label > .x-toggle-ios.x-toggle-btn:active {
  box-shadow: none;
}

.x-toggle:checked + label > .x-toggle-ios.x-toggle-btn:active::after {
  margin-left: -0.8em;
}

.x-toggle-ios.small {
  width: 3em;
  height: 1.6em;
}

.x-toggle-ios.medium {
  width: 4em;
  height: 2.1em;
  padding: 3px;
}

.x-toggle-ios.large {
  width: 4.7em;
  height: 2.1em;
  padding: 4px;
}

/* Dark mode styling */
.x-toggle-ios.dark.x-toggle-btn {
  background: var(--ios-track-dark);
  border: var( --ios-border-dark);
}

.x-toggle:checked + label > .x-toggle-ios.dark.x-toggle-btn {
  background: var(--ios-thumb-checked-dark);
}

/* Auto mode styling */
@media (prefers-color-scheme: dark) {
  .x-toggle-ios.auto.x-toggle-btn {
    background: var(--ios-track-dark);
    border: var( --ios-border-dark);
  }
  
  .x-toggle:checked + label > .x-toggle-ios.auto.x-toggle-btn {
    background: var(--ios-thumb-checked-dark);
  }
}
.x-toggle-light.x-toggle-btn {
  background: #f0f0f0;
  border-radius: 2em;
  padding: 2px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.x-toggle-light.x-toggle-btn::after {
  border-radius: 50%;
  background: #fff;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}

.x-toggle:checked + label > .x-toggle-light.x-toggle-btn {
  background: #9fd6ae;
}

.x-toggle-light.small {
  width: 3em;
  height: 1.6em;
}

.x-toggle-light.medium {
  width: 4em;
  height: 2.1em;
  padding: 3px;
}

.x-toggle-light.large {
  width: 4.7em;
  height: 2.1em;
  padding: 4px;
}

.x-toggle-flip.x-toggle-btn {
  padding: 2px;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  font-family: sans-serif;
  -webkit-perspective: 100px;
  perspective: 100px;
}

.x-toggle-flip.x-toggle-btn::after,
.x-toggle-flip.x-toggle-btn::before {
  display: inline-block;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  width: 100%;
  text-align: center;
  position: absolute;
  line-height: 2em;
  font-weight: bold;
  color: #fff;
  top: 0;
  left: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border-radius: 4px;
}

.x-toggle-flip.x-toggle-btn::after {
  content: attr(data-tg-on);
  background: #02c66f;
  -webkit-transform: rotateY(-180deg);
  transform: rotateY(-180deg);
}

.x-toggle-flip.x-toggle-btn::before {
  background: #ff3a19;
  content: attr(data-tg-off);
}

.x-toggle-flip.x-toggle-btn:active::before {
  -webkit-transform: rotateY(-20deg);
  transform: rotateY(-20deg);
}

.x-toggle:checked + label > .x-toggle-flip.x-toggle-btn::before {
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
}

.x-toggle:checked + label > .x-toggle-flip.x-toggle-btn::after {
  -webkit-transform: rotateY(0);
  transform: rotateY(0);
  left: 0;
  background: #7fc6a6;
}

.x-toggle:checked + label > .x-toggle-flip.x-toggle-btn:active::after {
  -webkit-transform: rotateY(20deg);
  transform: rotateY(20deg);
}

.x-toggle-flip.small {
  width: 3em;
  height: 1.6em;
}

.x-toggle-flip.small::before,
.x-toggle-flip.small::after {
  line-height: 2.2em;
  font-size: 0.8em;
}

.x-toggle-flip.medium {
  width: 4em;
  height: 2.1em;
  padding: 3px;
}

.x-toggle-flip.medium::before,
.x-toggle-flip.medium::after {
  line-height: 2.3em;
}

.x-toggle-flip.large {
  width: 4.7em;
  height: 2.1em;
  padding: 4px;
}

.x-toggle-flip.large::before,
.x-toggle-flip.large::after {
  line-height: 2.1em;
  font-size: 1.1em;
}

.liquid-container {
    position: relative;
    overflow: hidden;

    /* without this, overflow:hidden won't take effect because the things
       we're trying to hide are on a separate accelerated
       context. Also, this prevents a tiny vertical jump when the
       content switches to accelerated.  */
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    transform: translateY(0);
}

.liquid-child {
    overflow: hidden; /* Prevent margin collapse */
}

.occluded-content {
  display: block;
  position: relative;
  width: 100%;

  /* prevents margin overflow on item container */
  min-height: 0.01px;

  /* hides text visually while still being readable by screen readers */
  color: rgba(0,0,0,0);
}

table .occluded-content,
tbody .occluded-content,
thead .occluded-content,
tfoot .occluded-content {
  display: table-row;
  position: relative;
  width: 100%;
}

ul .occluded-content,
ol .occluded-content {
  display: list-item;
  position: relative;
  width: 100%;
  list-style-type: none;
  height: 0;
}

.ember-table {
  position: relative;
  height: 100%;
  width: 100%;
  box-sizing: border-box;
}

.ember-table .ember-table-overflow {
  overflow: auto;
  max-height: 100%;
  max-width: 100%;
}

.ember-table table {
  border-spacing: 0;
  table-layout: fixed;
  box-sizing: border-box;
}

.ember-table td,
.ember-table th {
  box-sizing: border-box;
}

.ember-table td.is-fixed-left,
.ember-table td.is-fixed-right,
.ember-table th.is-fixed-left,
.ember-table th.is-fixed-right {
  position: -webkit-sticky;
  position: sticky;
  left: 0;
}

.ember-table td.ember-table__text-align-left,
.ember-table th.ember-table__text-align-left {
  text-align: left;
}

.ember-table td.ember-table__text-align-center,
.ember-table th.ember-table__text-align-center {
  text-align: center;
}

.ember-table td.ember-table__text-align-right,
.ember-table th.ember-table__text-align-right {
  text-align: right;
}

.ember-table th {
  z-index: 2;
}

.ember-table th:not(.is-fixed-right) .et-header-resize-area {
  right: 0;
}

.ember-table th.is-fixed-right .et-header-resize-area {
  left: 0;
}

.ember-table td.is-fixed-left,
.ember-table td.is-fixed-right {
  z-index: 3;
}

.ember-table th.is-fixed-left,
.ember-table th.is-fixed-right {
  z-index: 4;
}

.ember-table th.is-sortable {
  cursor: pointer;
}

.ember-table thead {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 2;
  box-sizing: border-box;
}

.ember-table tbody {
  box-sizing: border-box;
}

.ember-table tfoot {
  position: -webkit-sticky;
  position: sticky;
  bottom: 0;
  z-index: 2;
  box-sizing: border-box;
}

.ember-table .scroll-indicator {
  position: absolute;
  z-index: 5;
}

.ember-table .scroll-indicator__left,
.ember-table .scroll-indicator__right {
  top: 0;
  width: 8px;
  height: 100%;
}

.ember-table .scroll-indicator__left {
  background: linear-gradient(to right, rgba(168, 168, 168, 0.4), rgba(168, 168, 168, 0));
}

.ember-table .scroll-indicator__right {
  right: 0;
  background: linear-gradient(to left, rgba(168, 168, 168, 0.4), rgba(168, 168, 168, 0));
}

.ember-table .scroll-indicator__top,
.ember-table .scroll-indicator__bottom {
  left: 0;
  width: 100%;
  height: 8px;
}

.ember-table .scroll-indicator__top {
  top: 0;
  background: linear-gradient(to bottom, rgba(168, 168, 168, 0.4), rgba(168, 168, 168, 0));
}

.ember-table .scroll-indicator__bottom {
  bottom: 0;
  background: linear-gradient(to top, rgba(168, 168, 168, 0.4), rgba(168, 168, 168, 0));
}

.ember-table.et-unselectable {
  user-select: none;
}

.ember-table .et-header-resize-area {
  cursor: col-resize;
  width: 10px;
  height: 100%;
  position: absolute;
  top: 0;
}

.ember-table .et-speech-only {
  display: none !important;
}

@media speech {
  .ember-table .et-speech-only {
    display: block !important;
  }
}

.ember-table .ember-table-loading-more {
  display: inline-block;
}

.default-liquid-destination {
  position: absolute;
  top: 0;
  left: 0;
  height: 0;

  width: 100%;
  z-index: 9999;
}

.default-liquid-destination .liquid-destination-stack {
  position: absolute;

  width: 100%;
}

.default-liquid-destination > .liquid-destination-stack > .liquid-child {
  position: absolute;
  top: 0;
  left: 0;

  width: 100%;
  overflow: visible;
  visibility: hidden;
}

.default-liquid-destination > .liquid-destination-stack > .liquid-child > div {
  position: absolute;
  top: 0;
  left: 0;

  width: 100%;
  height: 100vh;
  visibility: hidden;
}

.default-liquid-destination > .liquid-destination-stack > .liquid-child > div > * {
  visibility: visible;
}

.liquid-wormhole-container {
  display: none;
}
