void-textarea {
  display: flex;
  flex-direction: column;
  gap: var(--void-space-1);
  font-family: var(--void-font-sans);
}

void-textarea textarea {
  width: 100%;
  resize: var(--void-textarea-resize, vertical);
  padding: var(--void-space-2) var(--void-space-3);
  background: var(--void-color-bg-secondary);
  border: 1px solid var(--void-color-border);
  border-radius: var(--void-radius-md);
  color: var(--void-color-text);
  font-family: inherit;
  font-size: var(--void-text-sm);
  line-height: var(--void-leading-normal);
  outline: none;
  transition: border-color var(--void-duration-fast) var(--void-ease-in-out),
              box-shadow var(--void-duration-fast) var(--void-ease-in-out);
}

void-textarea textarea::placeholder {
  color: var(--void-color-text-muted);
}

void-textarea textarea:hover {
  border-color: var(--void-color-border-strong);
}

void-textarea textarea:focus {
  border-color: var(--void-color-border-focus);
  box-shadow: 0 0 0 1px var(--void-color-border-focus);
}

void-textarea textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

void-textarea[error]:not([error=""]) textarea {
  border-color: var(--void-color-error);
}

void-textarea[error]:not([error=""]) textarea:focus {
  box-shadow: 0 0 0 1px var(--void-color-error);
}

.void-textarea-error {
  color: var(--void-color-error);
  font-size: var(--void-text-xs);
}

void-textarea[size="sm"] textarea { padding: var(--void-space-1) var(--void-space-2); font-size: var(--void-text-xs); }
void-textarea[size="lg"] textarea { padding: var(--void-space-3) var(--void-space-4); font-size: var(--void-text-base); }
void-textarea[size="xl"] textarea { padding: var(--void-space-4) var(--void-space-5); font-size: var(--void-text-lg); }
void-textarea[size="xxl"] textarea { padding: var(--void-space-5) var(--void-space-6); font-size: var(--void-text-xl); }
