:host {
  display: block;
  width: 100%;
}

.nylas-specific-time-availability-picker {
  display: flex;
  margin: 1rem;
  flex-direction: column;
  border-radius: var(--nylas-border-radius-2x);
  border: 1px solid var(--nylas-base-200);
}
.nylas-specific-time-availability-picker .content {
  padding: 1.5rem;
  border-radius: var(--nylas-border-radius-2x);
  color: var(--nylas-base-900);
  font-size: 16px;
  font-family: var(--nylas-font-family);
  background: var(--nylas-base-25);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .content {
    padding: 1rem;
    gap: 1.25rem;
  }
}
.nylas-specific-time-availability-picker .header {
  padding: 1rem;
  border-bottom: 1px solid var(--nylas-base-200);
}
.nylas-specific-time-availability-picker .header h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  line-height: 20px;
  color: var(--nylas-base-900);
  text-align: left;
}
.nylas-specific-time-availability-picker .header p {
  margin: 0.25rem 0 0 0;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 20px;
  color: var(--nylas-base-600);
  text-align: left;
  display: flex;
  align-items: center;
  gap: 4px;
}
.nylas-specific-time-availability-picker .timezone-selector {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1.25rem;
  background: var(--nylas-base-0);
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .timezone-selector {
    padding: 1rem;
  }
}
.nylas-specific-time-availability-picker .timezone-selector .sub-header {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--nylas-base-900);
}
.nylas-specific-time-availability-picker .timezone-selector .timezone-description {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--nylas-base-600);
}
.nylas-specific-time-availability-picker .timezone-selector select-dropdown {
  margin-top: 0.25rem;
}
.nylas-specific-time-availability-picker .timezone-selector .timezone-error {
  margin-top: 0.5rem;
}
.nylas-specific-time-availability-picker .specific-times-section {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--nylas-base-0);
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
}
.nylas-specific-time-availability-picker .specific-times-section .section-header {
  margin: 0 0 0.5rem 0;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--nylas-base-900);
}
.nylas-specific-time-availability-picker .specific-times-section .section-description {
  margin: 0 0 1rem 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--nylas-base-600);
}
.nylas-specific-time-availability-picker .specific-times {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.nylas-specific-time-availability-picker .empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem 1rem;
  text-align: center;
}
.nylas-specific-time-availability-picker .empty-state .empty-icon {
  margin-bottom: 1.5rem;
  opacity: 0.4;
  color: var(--nylas-base-400);
}
.nylas-specific-time-availability-picker .empty-state .empty-title {
  margin: 0 0 0.5rem 0;
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--nylas-base-700);
  line-height: 1.5;
}
.nylas-specific-time-availability-picker .empty-state .empty-subtitle {
  margin: 0;
  font-size: 0.875rem;
  color: var(--nylas-base-500);
  line-height: 1.5;
  max-width: 300px;
}
.nylas-specific-time-availability-picker .specific-time-entry {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 1rem;
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
  background: var(--nylas-base-0);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.nylas-specific-time-availability-picker .specific-time-entry:hover {
  border-color: var(--nylas-base-300);
}
.nylas-specific-time-availability-picker .specific-time-entry:focus-within {
  border-color: var(--nylas-primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.nylas-specific-time-availability-picker .specific-time-entry .entry-content {
  display: grid;
  grid-template: 1fr auto/auto 1fr;
  gap: 0.75rem;
  align-items: center;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .specific-time-entry .entry-content {
    grid-template: unset;
    grid-template-areas: "date" "time_or_unavailable" "actions";
    grid-template-columns: 1fr auto auto;
    gap: 0.75rem;
  }
}
.nylas-specific-time-availability-picker .specific-time-entry .date-input-container {
  flex: 0 0 auto;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .specific-time-entry .date-input-container {
    grid-area: date;
  }
}
.nylas-specific-time-availability-picker .specific-time-entry .date-input-container .date-input {
  width: 100%;
}
.nylas-specific-time-availability-picker .specific-time-entry .date-input-container nylas-date-component::part(ic__date) {
  border: 1px solid var(--nylas-base-200);
  height: 48px;
  display: flex;
  align-items: center;
  border-radius: var(--nylas-border-radius);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.nylas-specific-time-availability-picker .specific-time-entry .date-input-container nylas-date-component::part(ic__date):focus-within {
  border-color: var(--nylas-primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.nylas-specific-time-availability-picker .specific-time-entry .time-pickers {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex: 1;
  min-width: 0;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .specific-time-entry .time-pickers {
    grid-area: time_or_unavailable;
  }
}
.nylas-specific-time-availability-picker .specific-time-entry .time-pickers nylas-time-window-picker {
  flex: 1;
  min-width: 0;
}
.nylas-specific-time-availability-picker .specific-time-entry .time-pickers .time-separator {
  font-size: 0.875rem;
  color: var(--nylas-base-600);
  font-weight: 500;
  flex-shrink: 0;
  line-height: 1;
  user-select: none;
}
.nylas-specific-time-availability-picker .specific-time-entry .unavailable-text {
  flex: 1;
  display: flex;
  align-items: center;
  padding: 0 1rem;
  border-radius: var(--nylas-border-radius);
  background: var(--nylas-base-50);
  border: 1px solid var(--nylas-base-200);
  min-height: 48px;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .specific-time-entry .unavailable-text {
    grid-area: time_or_unavailable;
  }
}
.nylas-specific-time-availability-picker .specific-time-entry .unavailable-text .unavailable-label {
  font-size: 0.875rem;
  color: var(--nylas-base-600);
  font-weight: 500;
}
.nylas-specific-time-availability-picker .specific-time-entry .action-buttons {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  grid-column: 2;
  justify-content: end;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .specific-time-entry .action-buttons {
    grid-area: actions;
    justify-self: end;
  }
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
  background: var(--nylas-base-0);
  color: var(--nylas-base-500);
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button:hover {
  background: var(--nylas-base-50);
  border-color: var(--nylas-primary);
  color: var(--nylas-primary);
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button:focus {
  outline: none;
  border-color: var(--nylas-primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button:active {
  background: var(--nylas-base-100);
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button.unavailable {
  background: var(--nylas-error-50);
  border-color: var(--nylas-error-200);
  color: var(--nylas-error);
}
.nylas-specific-time-availability-picker .specific-time-entry .toggle-button.unavailable:hover {
  background: var(--nylas-error-100);
  border-color: var(--nylas-error);
}
.nylas-specific-time-availability-picker .specific-time-entry .remove-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
  background: var(--nylas-base-0);
  color: var(--nylas-base-400);
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.nylas-specific-time-availability-picker .specific-time-entry .remove-button:hover {
  background: var(--nylas-error-50);
  border-color: var(--nylas-error-200);
  color: var(--nylas-error);
}
.nylas-specific-time-availability-picker .specific-time-entry .remove-button:focus {
  outline: none;
  border-color: var(--nylas-primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.nylas-specific-time-availability-picker .specific-time-entry .remove-button:active {
  background: var(--nylas-error-100);
}
.nylas-specific-time-availability-picker .specific-time-entry .error-message {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: var(--nylas-error-50);
  color: var(--nylas-error);
  font-size: 0.8125rem;
  line-height: 1.5;
  border-radius: var(--nylas-border-radius);
  border: 1px solid var(--nylas-error-200);
  margin-top: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.nylas-specific-time-availability-picker .add-button-container {
  display: flex;
  justify-content: flex-start;
  margin-top: 0.5rem;
}
.nylas-specific-time-availability-picker .add-button-container button-component {
  width: 100%;
}
@media (max-width: 768px) {
  .nylas-specific-time-availability-picker .add-button-container button-component {
    font-size: 0.875rem;
  }
}

::part(nstap__add-button) {
  border: 1px dashed var(--nylas-base-200);
  background: var(--nylas-base-0);
  color: var(--nylas-base-700);
}
::part(nstap__add-button):hover {
  border-color: var(--nylas-primary);
  background: var(--nylas-base-50);
  color: var(--nylas-primary);
}

::part(nstap__time-picker-container) {
  flex: 1;
  min-width: 0;
}

::part(nstap__time-picker-input) {
  width: 100%;
  font-size: 0.875rem;
  min-height: 48px;
  display: flex;
  align-items: center;
  border-radius: var(--nylas-border-radius);
}

::part(nstap__date-input) {
  width: 100%;
}

::part(nstap__date-field) {
  width: 100%;
  font-size: 0.875rem;
  border: 1px solid var(--nylas-base-200);
  border-radius: var(--nylas-border-radius);
  padding: 0.5rem 0.75rem;
}
::part(nstap__date-field):focus {
  border-color: var(--nylas-primary);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

::part(nstap__date-wrapper) {
  margin: 0;
}

::part(nstap__date-label) {
  margin: 0;
  padding: 0;
}
::part(nstap__date-label) p {
  display: none;
}