html {
  font-size: 100%;
}

body {
  color: var(--q-dark);
}

.bg-light-grey {
  background-color: var(--q-light-grey);
}

.text-light-grey {
  color: var(--q-light-grey);
}

.text-jagged-ice {
  color: #B9DDFA;
}

.bg-jagged-ice {
  background-color: #B9DDFA;
}

.text-lefas-grey {
  color: #808080;
}

.bg-lefas-grey {
  background-color: white;
}

.text-answer {
  color: var(--q-secondary);
}

.text-hangup {
  color: #DE2C5C;
}

.bg-hangup {
  background: white;
}

.text-call-stage-button {
  color: #828282;
}

.bg-call-stage-button {
  background: white;
}

.text-call-stage-button-dark {
  color: #808080;
}

.bg-call-stage-button-dark {
  background: white;
}

.text-secondary-a25 {
  color: var(--q-dark) !important;
}

.bg-secondary-a25 {
  background: var(--q-secondary-a25) !important;
}

.text-avatar-color-1 {
  color: #3a31df;
}

.bg-avatar-color-1 {
  background: white;
}

.text-avatar-color-2 {
  color: #8d1874;
}

.bg-avatar-color-2 {
  background: white;
}

.text-avatar-color-3 {
  color: #114232;
}

.bg-avatar-color-3 {
  background: white;
}

.text-avatar-color-4 {
  color: #254983;
}

.bg-avatar-color-4 {
  background: white;
}

.text-professional-appointment-1 {
  color: #B9DDFA;
}

.bg-professional-appointment-1 {
  background: #B9DDFA;
}

.text-professional-appointment-2 {
  color: #8EC3E2;
}

.bg-professional-appointment-2 {
  background: #8EC3E2;
}

.text-professional-appointment-3 {
  color: #F2A0CE;
}

.bg-professional-appointment-3 {
  background: #F2A0CE;
}

.text-professional-appointment-4 {
  color: #5CC0B9;
}

.bg-professional-appointment-4 {
  background: #5CC0B9;
}

.text-professional-appointment-5 {
  color: #DBBDF0;
}

.bg-professional-appointment-5 {
  background: #DBBDF0;
}

.text-professional-appointment-6 {
  color: #F59C37;
}

.bg-professional-appointment-6 {
  background: #F59C37;
}

.text-professional-appointment-7 {
  color: #FF779C;
}

.bg-professional-appointment-7 {
  background: #FF779C;
}

.text-professional-appointment-8 {
  color: #CCCCCC;
}

.bg-professional-appointment-8 {
  background: #CCCCCC;
}

.text-weight-medium {
  font-weight: 600;
}

.text-grey-400 {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5rem;
  letter-spacing: 0.01em;
  color: var(--q-dark-50);
}

.text-extra-small {
  font-size: 0.6875rem;
}

.text-small {
  font-size: 0.75rem;
  font-weight: 400;
  letter-spacing: 0.01em;
}

.text-400 {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: normal;
}

.text-600 {
  font-size: 0.875rem;
  font-weight: 600;
}

.text-large-400 {
  font-size: 1rem;
  font-weight: 400;
  line-height: normal;
}

.text-h7 {
  font-size: 1rem;
  line-height: 2rem;
  letter-spacing: 0.01em;
}

.text-h7-0 {
  font-size: 1rem;
  line-height: 1.5rem;
  letter-spacing: 0.01em;
}

.text-h7-600 {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5rem;
  letter-spacing: 0.01em;
}

.text-h6 {
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 2rem;
  letter-spacing: 0.0125em;
}

.text-h6-600 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 2rem;
  letter-spacing: 0.0125em;
}

.text-caption {
  font-size: 0.925em;
  color: var(--q-dark-75);
  font-weight: 500;
}

.subtle {
  font-size: 0.925em;
  color: var(--q-dark-50);
  font-weight: 400;
  white-space: nowrap;
}

.text-subtle {
  color: var(--q-dark-50);
}

.text-disabled {
  color: var(--q-dark-25);
}

a.link {
  line-height: 1;
  text-decoration: none;
  font-weight: 500;
  color: var(--q-primary) !important;
}
a.link:hover {
  text-decoration: underline;
  cursor: pointer;
}
a.link.disabled {
  color: currentColor;
  cursor: not-allowed;
  opacity: 0.5;
  text-decoration: none;
}
a.link.white {
  color: white !important;
}

.link-default {
  line-height: 1;
  text-decoration: none;
  font-weight: 500;
  color: var(--q-primary) !important;
}
.link-default:hover {
  text-decoration: underline;
  cursor: pointer;
}
.link-default.disabled {
  color: currentColor;
  cursor: not-allowed;
  opacity: 0.5;
  text-decoration: none;
}
.link-default.white {
  text-decoration: underline;
  color: white !important;
}

.flex-grow-2 {
  flex-grow: 2;
}

.flex-grow, .flex-grow-1 {
  flex-grow: 1;
}

.flex-grow-0 {
  flex-grow: 0;
}

.q-btn {
  text-transform: none;
}

.q-dialog .q-dialog__inner .q-card {
  padding: 4px;
}

.q-table {
  /* fixed is required when using ellipsis class in column definitions */
  table-layout: fixed;
}
.q-table tbody td, .q-table th {
  font-size: 14px;
}
.q-table th {
  font-weight: 600 !important;
}
.q-table td, .q-table th {
  padding: 7px 8px;
  text-overflow: ellipsis;
  white-space: pre-wrap;
  overflow: hidden;
}

.q-table--dense .q-table thead tr, .q-table--dense .q-table tbody tr, .q-table--dense .q-table tbody td {
  height: 28px;
}
.q-table--dense .q-table th, .q-table--dense .q-table td {
  padding: 4px 4px;
  font-size: 0.875em !important;
}

.q-table__bottom--nodata {
  position: absolute;
  bottom: 0;
  width: 100%;
  top: 0;
  border-top: none;
}

.q-notification__caption {
  font-weight: 500;
}

.sticky-header {
  /* height or max-height is important 
     and is to be defined in the individual components */
  /* this is when the loading indicator appears */
  /* height of all previous header rows */
}
.sticky-header.empty {
  height: unset !important;
}
.sticky-header .text-accent {
  color: var(--q-dark) !important;
  opacity: 0.5;
}
.sticky-header .q-table__top,
.sticky-header .q-table__bottom,
.sticky-header thead tr:first-child th {
  /* bg color is important for th; just specify one */
  background-color: white;
}
.sticky-header thead tr th {
  position: sticky;
  z-index: 1;
}
.sticky-header thead tr:first-child th {
  top: 0;
}

.q-field--outlined.q-field--readonly .q-field__control:before {
  border-style: solid;
}

.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.4s ease;
}

/* Starting at low opacity values instead of 0 to fix the lighthouse test issue (it requires content to be visible on the first load) */
.fade-enter-from,
.fade-leave-to {
  opacity: 0.001;
}

.vcs-backdrop {
  /* slightly gradient fallback */
  /* if backdrop support: very transparent and blurred */
}
.vcs-backdrop .q-dialog__backdrop {
  background: transparent linear-gradient(129deg, var(--q-secondary-25) 0%, var(--q-secondary) 100%) 0% 0% no-repeat padding-box;
}
@supports ((-webkit-backdrop-filter: none) or (backdrop-filter: none)) {
  .vcs-backdrop .q-dialog__backdrop {
    background: transparent linear-gradient(129deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 100%) 0% 0% no-repeat padding-box;
    -webkit-backdrop-filter: blur(20px) brightness(65%);
    backdrop-filter: blur(20px) brightness(65%);
  }
}
.vcs-backdrop.gradient-only .q-dialog__backdrop {
  background: transparent linear-gradient(129deg, rgba(0, 0, 0, 0) 20%, var(--q-secondary-a75) 100%) 0% 0% no-repeat padding-box;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

::-webkit-scrollbar {
  appearance: none;
  width: 7px;
}

::-webkit-scrollbar-thumb {
  border-radius: 4px;
  background-color: rgba(0, 0, 0, 0.5);
  box-shadow: 0 0 1px rgba(255, 255, 255, 0.5);
}
