.availability-directive-backdrop.ng-hide {
  opacity: 0;
}

.availability-directive-backdrop.ng-hide-add, .availability-directive-backdrop.ng-hide-remove {
  transition: opacity 450ms;
}

.availability-directive-backdrop {
  width: 100vw;
  height: calc(100 * var(--window-inner-height));
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 77;
  outline: none;
  background-color: rgba(var(--backdrop-color));
}

.availability-directive-wrapper {
  position: relative;
}

.availability-directive {
  box-sizing: border-box;
  width: 395px;
  max-width: calc(100 * var(--window-inner-height));
  background-color: rgba(var(--background-content));
  position: fixed;
  margin: 8px;
  top: calc(var(--navbar-top-height) + env(safe-area-inset-top, 0));
  right: 0;
  z-index: 78;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);
  display: flex;
  flex-direction: column;
  font-size: 12pt;
  border-radius: var(--default-radius-large);
  overflow: hidden;
  /* bottom: calc(var(--navbar-bottom-height) + env(safe-area-inset-bottom, 0)); */
}

.availability-button {
  align-items: center;
  justify-content: center;
  display: inline-flex;
  position: relative;
}

.availability-button i {
  display: inline-flex;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background-color: rgba(var(--color-success));
}

.availability-button i.is-away {
  background-color: rgba(var(--color-warn));
}
.availability-button i.is-not-working {
  background-color: rgba(var(--color-alpha-grey));
}

.availability-button md-icon {
  position: absolute;
  top: 4px;
  right: 50%;
  transform: translateX(16px);
  height: 12px;
  width: 12px;
  min-height: 12px;
  min-width: 12px;
}

.availability-directive-toolbar {
  display: flex;
  height: 48px;
  padding: 8px;
  box-sizing: border-box;
  justify-content: center;
  align-items: center;
  background-color: rgba(var(--toolbar-color));
  color: rgba(var(--toolbar-font-color));
}

.availability-directive-toolbar h2 {
  font-size: 12pt;
  font-weight: normal;
  text-align: left;
}

.availability-directive-toolbar button {
  box-sizing: border-box;
  min-width: 0 !important;
  width: 36px !important;
  height: 36px !important;
  padding: 0;
  margin: 0;
}

.availability-directive-toolbar button md-icon {
  color: rgba(var(--toolbar-font-color)) !important;
}

.availability-directive .availability-directive-content {
  box-sizing: border-box;
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.availability-directive-full-height {
  flex: 1;
  align-items: flex-start;
}

.availabilty-directive-datetime-picker-wrapper input {
  font-size: 12pt;
  border: none;
}

.availability-directive-content-status-message-wrapper .md-icon-button {
  position: absolute;
  right: 16px;
  padding: 0;
  margin: 0;
  height: 24px;
  width: 24px;
  min-height: 24px;
  min-width: 24px;
  box-sizing: border-box;
}

.availability-directive-content-status-message {
  display: flex;
  flex: 1;
  border: none;
  outline: none;
  border-bottom: 1px solid rgba(var(--primary-color));
  font-size: 12pt;
}

.availability-directive .availability-directive-own-date-selected-input-container {
  margin: 0;
  margin-bottom: 4px;
}

.availability-directive .availability-directive-own-date-selected-input-container .md-errors-spacer {
  display: none;
}

.availability-directive .availability-directive-content-status-time-wrapper {
  display: flex;
  flex: 1;
  font-size: 12pt;
  padding: 0 8px;
}

.availability-directive .availability-directive-content-status-time-wrapper label {
  font-size: 9pt;
  flex: 1;
  justify-content: start;
  align-items: center;
  display: flex;
  outline: none;
}

.availability-directive .availability-directive-content-status-time-wrapper .select-time-away-wrapper {
  display: flex;
  flex-direction: column;
  padding: 8px;
}

.availability-directive .availability-directive-content-status-time-wrapper .select-time-away-wrapper select {
  border: none;
  background: none;
  outline: none;
  font-size: 12pt;
  padding: 4px 0;
  color: rgba(var(--font-color));
  background-color: rgba(var(--background-content));
}

.availability-directive .availability-directive-content-status-time-wrapper .select-time-away-wrapper select option {
  background-color: rgba(var(--background-content));
}

.availability-directive .availability-directive-is-forwarding-calls {
  padding-top: 8px;
  font-style: italic;
  font-size: 10pt;
}

.availability-directive .availability-directive-is-forwarding-calls md-icon {
  height: 18px;
  width: 18px;
  min-height: 18px;
  min-width: 18px;
}

.availability-directive .availability-directive-actions {
  box-sizing: border-box;
  display: flex;
  height: 52px;
  justify-content: flex-end;
  align-items: center;
  background-color: rgba(var(--background-content-accent));
}

.availability-directive .availability-directive-actions button {
  min-width: inherit !important;
  max-width: inherit !important;
  min-height: 36px !important;
  max-height: 36px !important;
  margin: 6px !important;
}

.availability-directive .availability-directive-actions button:last-child {
  flex-grow: 2;
}

.availability-directive .availability-directive-actions button.md-raised span {
  display: inline-block !important;
}

.availability-directive .availability-directive-actions button:not([disabled]):not(.md-raised) span {
  font-size: 9pt;
  display: inline-block !important;
  color: rgba(var(--primary-color)) !important;
}

.availability-directive .availability-directive-actions button:not([disabled]):not(.md-raised) md-icon {
  color: rgba(var(--primary-color)) !important;
}

.availability-directive .availability-directive-actions button.md-primary.md-raised span {
  color: rgba(var(--primary-button-font-color));
}

@media (max-width: 599px) {
  .availability-directive {
    min-width: 0;
    width: 100%;
    margin: 0;
    box-shadow: none;
    box-sizing: content-box;
    bottom: calc(var(--navbar-bottom-height) + env(safe-area-inset-bottom, 0));
    left: env(safe-area-inset-left, 0);
    right: env(safe-area-inset-right, 0);
    border-radius: 0;
  }
  .availability-directive .availability-directive-actions {
    padding: 8px 0;
  }
}