:host {
  position: relative;
  box-sizing: border-box;
  font-feature-settings: "cv03", "cv04", "cv11";
}
:host *, :host *:before, :host *:after {
  box-sizing: inherit;
}

:host {
  display: block;
}

p {
  margin: 0px;
}

.upload__area {
  border: var(--sl-input-border-width) dashed var(--sl-input-border-color);
  border-radius: var(--sl-input-border-radius-medium);
  padding: var(--sl-spacing-x-large);
  padding-top: var(--sl-spacing-large);
  justify-content: center;
  display: flex;
}

.elements {
  text-align: center;
}
.elements > * + * {
  margin-top: var(--sl-spacing-4x-small);
}
.elements > * {
  flex: auto;
  justify-content: center;
}

.icon-wrapper {
  margin-left: auto;
  margin-right: auto;
  font-size: var(--sl-font-size-xx-large);
  line-height: var(--sl-font-size-xx-large);
  color: var(--sl-color-gray-400);
}

.upload-wrapper {
  display: flex;
  font-size: var(--sl-font-size-small);
  color: var(--sl-color-gray-600);
}
.upload-wrapper > label {
  position: relative;
  cursor: pointer;
  color: var(--sl-color-indigo-600);
  font-weight: var(--sl-font-weight-normal);
}
.upload-wrapper > label:hover {
  color: var(--sl-color-indigo-500);
}
.upload-wrapper > label:focus-within {
  outline: 2px solid transparent;
  outline-offset: 2px;
  border-radius: var(--sl-border-radius-small);
  box-shadow: 0 0 0 var(--sl-focus-ring-width) var(--sl-focus-ring-color-primary);
}
.upload-wrapper > p {
  padding-left: var(--sl-spacing-xx-small);
}

input {
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  height: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  width: 1px;
}

.description {
  font-size: var(--sl-font-size-x-small);
  color: var(--sl-color-gray-500);
}