.dropzone {
  border: var(--border-width-medium) var(--border-style-dashed) var(--primary-400);
  border-radius: var(--radius-2xl);
  background-color: var(--gray-100);
  padding: var(--spacing-8);

  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-5);

  width: 100%;
  min-height: 196px;

  transition: all 0.2s ease-in-out;
  cursor: pointer;
}

.dropzone:hover,
.dz-clickable.dz-drag-hover {
  border-color: var(--primary-400);
  box-shadow: 0 0 0 4px var(--primary-200);
  background-color: var(--primary-50);
}

.dropzone__icon {
  font-size: var(--font-size-3xl);
  color: var(--primary-800);
  margin-bottom: var(--spacing-2);
  line-height: var(--line-height-xtight);
}

.dropzone__message {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-tight);
  color: var(--gray-900);
  text-align: center;
  margin: 0;
}

.dropzone__hint {
  font-size: var(--font-size-xs);
  color: var(--gray-600);
  text-align: center;
  margin: 0;
  line-height: var(--line-height-tight);
}

.dropzone__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
  padding: var(--spacing-2) var(--spacing-5);

  background-color: var(--primary-700);
  color: var(--gray-25);

  border: none;
  border-radius: var(--radius-lg);

  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  margin-top: var(--spacing-6);
  pointer-events: auto;
  width: 200px;
  height: var(--spacing-10);
}

.dropzone__button:hover {
  background-color: var(--primary-800);
}

.dropzone__button:active {
  background-color: var(--primary-900);
}

.dropzone__button i {
  font-size: var(--font-size-base);
}

/* Start - Disabled */

.dropzone--disabled,
.dropzone[aria-disabled="true"] {
  pointer-events: none;
  cursor: not-allowed;
  opacity: 0.6;
  border-color: var(--gray-400);
  background-color: var(--gray-100);
}

.dropzone--disabled .dropzone__icon,
.dropzone[aria-disabled="true"] .dropzone__icon {
  color: var(--gray-400);
}

.dropzone--disabled .dropzone__message,
.dropzone[aria-disabled="true"] .dropzone__message {
  color: var(--gray-500);
}

.dropzone--disabled .dropzone__hint,
.dropzone[aria-disabled="true"] .dropzone__hint {
  color: var(--gray-400);
}

.dropzone--disabled .dropzone__button,
.dropzone[aria-disabled="true"] .dropzone__button {
  background-color: var(--gray-300);
  color: var(--gray-500);
  cursor: not-allowed;
}

.dropzone--disabled:hover,
.dropzone[aria-disabled="true"]:hover {
  border-color: var(--gray-300);
  box-shadow: none;
  background-color: var(--gray-100);
}

/* End - Disabled */

/* Start - Dropzone previews */

.dropzone__previews {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-5);
  width: 100%;
}

.dz-preview {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: var(--radius-lg);
  padding: var(--spacing-2) var(--spacing-4);
  margin: 0;
  min-height: 56px;
}

.dropzone__preview-content {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
}

.dropzone__preview-content-info {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
  flex: 1;
  min-width: 0;
}

.dz-filename {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--line-height-tight);
  color: var(--gray-900);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin: 0;
}

.dz-size {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-tight);
  color: var(--gray-600);
  margin: 0;
}

.dz-progress {
  width: 99%;
  display: none;
}

.dz-success {
  background-color: var(--primary-50);
}

.dz-processing {
  background-color: var(--gray-100);
}

.dz-error {
  background-color: var(--error-50);
}

.dropzone__preview-error-message {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-tight);
  color: var(--error-700);
  margin: 0;
  display: none;
}

.dropzone__preview-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-xl);
  color: var(--error-700);
  min-width: var(--spacing-12);
  height: var(--spacing-12);
  cursor: pointer;
  transition: all 0.2s ease-in-out;
  border: none;
  background: none;
  flex-shrink: 0;
  border-radius: var(--radius-lg);
}

.dropzone__preview-remove:hover {
  color: var(--error-800);
  background-color: var(--error-100);
}

.dropzone__preview-icon {
  font-size: var(--font-size-5xl);
  margin-right: var(--spacing-6);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dz-success .dropzone__preview-icon,
.dz-processing .dropzone__preview-icon {
  color: var(--primary-700);
}

.dz-error .dropzone__preview-icon {
  color: var(--error-800);
}

.dz-processing .dz-progress,
.dz-processing .dropzone__icon-cancel,
.dz-error .dropzone__icon-cancel,
.dz-error .dropzone__preview-error-message,
.dz-success .dropzone__icon-trash {
  display: flex !important;
}

.dz-error .dz-size,
.dz-error .dz-progress,
.dz-error .dropzone__icon-trash,
.dz-processing .dropzone__icon-trash,
.dz-success .dz-progress,
.dz-success .dropzone__icon-cancel,
.dz-max-files-reached .dropzone {
  display: none !important;
}

/* End - Dropzone previews */