/* Textarea Component */

/* WCAG 2.2 AAA compliant */

/* ========================================
   CSS Custom Properties
   ======================================== */

:root {
  /* Textarea sizes */
  --textarea-min-height-xs: 4rem;     /* ~3 rows */
  --textarea-min-height-s: 5rem;      /* ~4 rows */
  --textarea-min-height-m: 6rem;      /* ~5 rows - default */
  --textarea-min-height-l: 8rem;      /* ~7 rows */
  --textarea-min-height-xl: 10rem;    /* ~9 rows */

  --textarea-padding-x-xs: var(--ds-space-xs);
  --textarea-padding-x-s: var(--ds-space-s);
  --textarea-padding-x-m: var(--ds-space-m);
  --textarea-padding-x-l: var(--ds-space-l);
  --textarea-padding-x-xl: var(--ds-space-xl);

  --textarea-padding-y-xs: var(--ds-space-xs);
  --textarea-padding-y-s: var(--ds-space-s);
  --textarea-padding-y-m: var(--ds-space-s);
  --textarea-padding-y-l: var(--ds-space-m);
  --textarea-padding-y-xl: var(--ds-space-m);

  --textarea-font-size-xs: var(--ds-font-size-xs);
  --textarea-font-size-s: var(--ds-font-size-s);
  --textarea-font-size-m: var(--ds-font-size-m);
  --textarea-font-size-l: var(--ds-font-size-l);
  --textarea-font-size-xl: var(--ds-font-size-xl);

  /* Textarea colors - default/outlined */
  --textarea-bg: var(--ds-color-surface);
  --textarea-bg-hover: var(--ds-color-surface);
  --textarea-bg-focus: var(--ds-color-surface);
  --textarea-bg-disabled: var(--ds-color-surface-lowered);
  --textarea-bg-readonly: var(--ds-color-surface-raised);

  --textarea-border-color: var(--ds-color-border);
  --textarea-border-color-hover: var(--ds-color-border-hover);
  --textarea-border-color-focus: var(--ds-color-accent);
  --textarea-border-color-error: var(--ds-color-status-danger);
  --textarea-border-color-success: var(--ds-color-status-success);
  --textarea-border-color-disabled: var(--ds-color-border);

  --textarea-text-color: var(--ds-color-text);
  --textarea-text-color-disabled: var(--ds-color-text-weakest);
  --textarea-text-color-placeholder: var(--ds-color-text-weaker);

  /* Textarea styles */
  --textarea-border-width: 1px;
  --textarea-border-radius: var(--ds-radius-s);
  --textarea-transition: all var(--ds-duration-fast) var(--ds-ease-out);

  /* Focus ring */
  --textarea-focus-ring-width: 2px;
  --textarea-focus-ring-color: var(--ds-color-accent);
  --textarea-focus-ring-offset: 2px;

  /* Label */
  --textarea-label-font-size: var(--ds-font-size-s);
  --textarea-label-font-weight: var(--ds-font-weight-medium);
  --textarea-label-color: var(--ds-color-text);
  --textarea-label-margin: var(--ds-space-xs);

  /* Helper text */
  --textarea-helper-font-size: var(--ds-font-size-xs);
  --textarea-helper-color: var(--ds-color-text-weak);
  --textarea-helper-margin: var(--ds-space-xs);

  /* Error text */
  --textarea-error-color: var(--ds-color-status-danger);
  --textarea-error-font-size: var(--ds-font-size-xs);

  /* Success text */
  --textarea-success-color: var(--ds-color-status-success);
  --textarea-success-font-size: var(--ds-font-size-xs);

  /* Character counter */
  --textarea-counter-font-size: var(--ds-font-size-xs);
  --textarea-counter-color: var(--ds-color-text-weak);
}

/* ========================================
   Base Textarea Container
   ======================================== */

.c-textarea {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--textarea-label-margin);
}

/* ========================================
   Textarea Label
   ======================================== */

.c-textarea__label {
  display: flex;
  align-items: center;
  gap: var(--ds-space-xs);
  font-size: var(--textarea-label-font-size);
  font-weight: var(--textarea-label-font-weight);
  color: var(--textarea-label-color);
  line-height: 1.2;
}

.c-textarea__label--required::after {
  content: " *";
  color: var(--ds-color-status-danger);
}

/* ========================================
   Textarea Wrapper
   ======================================== */

.c-textarea__wrapper {
  position: relative;
  display: flex;
  width: 100%;
}

/* ========================================
   Textarea Field Base
   ======================================== */

.c-textarea__field {
  width: 100%;
  min-height: var(--textarea-min-height-m);
  padding: var(--textarea-padding-y-m) var(--textarea-padding-x-m);
  font-family: var(--ds-font-family-sans);
  font-size: var(--textarea-font-size-m);
  line-height: 1.5;
  color: var(--textarea-text-color);
  background: var(--textarea-bg);
  border: var(--textarea-border-width) solid var(--textarea-border-color);
  border-radius: var(--textarea-border-radius);
  transition: var(--textarea-transition);
  appearance: none;
  outline: none;
  resize: vertical;
}

.c-textarea__field::placeholder {
  color: var(--textarea-text-color-placeholder);
  opacity: 1;
}

/* ========================================
   Textarea States
   ======================================== */

/* Hover */
.c-textarea__field:hover:not(:disabled):not(:read-only) {
  background: var(--textarea-bg-hover);
  border-color: var(--textarea-border-color-hover);
}

/* Focus */
.c-textarea__field:focus:not(:disabled):not(:read-only) {
  background: var(--textarea-bg-focus);
  border-color: var(--textarea-border-color-focus);
  box-shadow: 0 0 0 var(--textarea-focus-ring-width) rgba(13, 86, 150, 0.2);
}

/* Disabled */
.c-textarea__field:disabled {
  background: var(--textarea-bg-disabled);
  border-color: var(--textarea-border-color-disabled);
  color: var(--textarea-text-color-disabled);
  cursor: not-allowed;
  opacity: 0.6;
  resize: none;
}

/* Readonly */
.c-textarea__field:read-only {
  background: var(--textarea-bg-readonly);
  cursor: default;
  resize: none;
}

/* Error state */
.c-textarea--error .c-textarea__field {
  border-color: var(--textarea-border-color-error);
}

.c-textarea--error .c-textarea__field:focus {
  border-color: var(--textarea-border-color-error);
  box-shadow: 0 0 0 var(--textarea-focus-ring-width) rgba(210, 64, 35, 0.2);
}

/* Success state */
.c-textarea--success .c-textarea__field {
  border-color: var(--textarea-border-color-success);
}

.c-textarea--success .c-textarea__field:focus {
  border-color: var(--textarea-border-color-success);
  box-shadow: 0 0 0 var(--textarea-focus-ring-width) rgba(29, 134, 51, 0.2);
}

/* ========================================
   Textarea Sizes
   ======================================== */

/* XS */
.c-textarea--size-xs .c-textarea__field {
  min-height: var(--textarea-min-height-xs);
  padding: var(--textarea-padding-y-xs) var(--textarea-padding-x-xs);
  font-size: var(--textarea-font-size-xs);
}

/* S */
.c-textarea--size-s .c-textarea__field {
  min-height: var(--textarea-min-height-s);
  padding: var(--textarea-padding-y-s) var(--textarea-padding-x-s);
  font-size: var(--textarea-font-size-s);
}

/* M - default */
.c-textarea--size-m .c-textarea__field {
  min-height: var(--textarea-min-height-m);
  padding: var(--textarea-padding-y-m) var(--textarea-padding-x-m);
  font-size: var(--textarea-font-size-m);
}

/* L */
.c-textarea--size-l .c-textarea__field {
  min-height: var(--textarea-min-height-l);
  padding: var(--textarea-padding-y-l) var(--textarea-padding-x-l);
  font-size: var(--textarea-font-size-l);
}

/* XL */
.c-textarea--size-xl .c-textarea__field {
  min-height: var(--textarea-min-height-xl);
  padding: var(--textarea-padding-y-xl) var(--textarea-padding-x-xl);
  font-size: var(--textarea-font-size-xl);
}

/* ========================================
   Textarea Variants
   ======================================== */

/* Filled variant */
.c-textarea--filled .c-textarea__field {
  background: var(--ds-color-surface-raised);
  border-color: transparent;
}

.c-textarea--filled .c-textarea__field:hover:not(:disabled) {
  background: var(--ds-color-surface-hover);
}

.c-textarea--filled .c-textarea__field:focus:not(:disabled) {
  background: var(--textarea-bg-focus);
  border-color: var(--textarea-border-color-focus);
}

/* No resize variant */
.c-textarea--no-resize .c-textarea__field {
  resize: none;
}

/* Auto-resize variant */
.c-textarea--auto-resize .c-textarea__field {
  resize: none;
  overflow: hidden;
}

/* ========================================
   Helper Text & Messages
   ======================================== */

.c-textarea__helper {
  display: flex;
  align-items: flex-start;
  gap: var(--ds-space-xs);
  font-size: var(--textarea-helper-font-size);
  color: var(--textarea-helper-color);
  line-height: 1.4;
  margin-top: var(--textarea-helper-margin);
}

.c-textarea__error {
  display: flex;
  align-items: flex-start;
  gap: var(--ds-space-xs);
  font-size: var(--textarea-error-font-size);
  color: var(--textarea-error-color);
  line-height: 1.4;
  margin-top: var(--textarea-helper-margin);
}

.c-textarea__success {
  display: flex;
  align-items: flex-start;
  gap: var(--ds-space-xs);
  font-size: var(--textarea-success-font-size);
  color: var(--textarea-success-color);
  line-height: 1.4;
  margin-top: var(--textarea-helper-margin);
}
.c-textarea__helper {
  color: var(--select-helper-color);
}
.c-textarea__helper.nline {
  display: block;
  width: 100%;
  text-align: left;
  font-size: var(--select-hint-font-size, var(--ds-font-size-s));
  color: var(--select-hint-color, var(--ds-color-text-weak));
  line-height: var(--select-line-height);
  margin-top: var(--ds-space-2xs, 0.25rem);
}
div.c-textarea__helper p,
div.c-textarea__helper span,
div.c-textarea__helper ul li,
div.c-textarea__helper ol li {
  margin: 0; 
  margin-top: var(--select-helper-margin);
}
div.c-textarea__helper p,
div.c-textarea__helper span {
  padding: 0;
}
div.c-textarea__helper ul li,
div.c-textarea__helper ol li {
  margin: var(--select-helper-margin) 0 0 1.5rem;
}
div.c-textarea__helper ul li {
  list-style: disc;
  padding-left: .4rem;
}
div.c-textarea__helper ol li {
  list-style: decimal;
  padding-left: .4rem;
}
.c-textarea:not(.c-textarea--error):not(.c-textarea--success) .c-textarea__error,
.c-textarea:not(.c-textarea--error):not(.c-textarea--success) .c-textarea__success {
  display: none !important;
}
.c-textarea.c-textarea--error .c-textarea__success,
.c-textarea.c-textarea--success .c-textarea__error,
.c-textarea.c-textarea--error:not([data-show-helper-always="true"]) .c-textarea__helper,
.c-textarea.c-textarea--success:not([data-show-helper-always="true"]) .c-textarea__helper {
  display: none !important; 
}

/* ========================================
   Character Counter
   ======================================== */

.c-textarea__counter {
  display: flex;
  justify-content: flex-end;
  font-size: var(--textarea-counter-font-size);
  color: var(--textarea-counter-color);
  margin-top: var(--ds-space-xs);
}

.c-textarea__counter--warning {
  color: var(--ds-color-status-warning);
}

.c-textarea__counter--error {
  color: var(--ds-color-status-danger);
}

/* ========================================
   Accessibility & Focus Management
   ======================================== */

/* Focus visible for keyboard navigation */
.c-textarea__field:focus-visible {
  outline: var(--textarea-focus-ring-width) solid var(--textarea-focus-ring-color);
  outline-offset: var(--textarea-focus-ring-offset);
}

/* High contrast mode */
@media (prefers-contrast: high) {
  .c-textarea__field {
    border-width: 2px;
  }

  .c-textarea__field:focus {
    outline-width: 3px;
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .c-textarea__field,
  .c-textarea__label {
    transition: none;
  }
}

/* ========================================
   Responsive Design
   ======================================== */

@media (max-width: 640px) {
  .c-textarea__field {
    font-size: 16px; /* Prevent zoom on iOS */
  }
}

/* ========================================
   Print Styles
   ======================================== */

@media print {
  .c-textarea__field {
    border: 1px solid #000;
    background: white;
  }

  .c-textarea__helper,
  .c-textarea__counter {
    display: none;
  }
}

/* ========================================
   Toolbar
   ======================================== */

.c-textarea__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--ds-space-xs);
  padding: var(--ds-space-xs) var(--ds-space-s);
  background: var(--ds-color-surface-raised);
  border: var(--textarea-border-width) solid var(--textarea-border-color);
  border-bottom: none;
  border-radius: var(--textarea-border-radius) var(--textarea-border-radius) 0 0;
}

.c-textarea--with-toolbar {
  gap: 0;
}
.c-textarea--with-toolbar .c-textarea__toolbar {
  margin-top: var(--textarea-label-margin);
}


.c-textarea--with-toolbar .c-textarea__wrapper {
  margin-top: 0;
}

.c-textarea--with-toolbar .c-textarea__field {
  border-radius: 0 0 var(--textarea-border-radius) var(--textarea-border-radius);
}

.c-textarea__toolbar-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--ds-radius-xs);
  color: var(--ds-color-text-weak);
  cursor: pointer;
  transition: var(--textarea-transition);
}

.c-textarea__toolbar-btn:hover {
  background: var(--ds-color-surface-hover);
  color: var(--ds-color-text);
}

.c-textarea__toolbar-btn:focus-visible {
  outline: var(--textarea-focus-ring-width) solid var(--textarea-focus-ring-color);
  outline-offset: 1px;
}

.c-textarea__toolbar-btn.is-active {
  background: var(--ds-color-accent-subtle);
  color: var(--ds-color-accent);
}

.c-textarea__toolbar-divider {
  width: 1px;
  height: 1.25rem;
  background: var(--ds-color-border);
  margin: 0 var(--ds-space-xs);
}

/* ========================================
   Clear Button
   ======================================== */

.c-textarea__clear {
  position: absolute;
  top: var(--ds-space-s);
  right: var(--ds-space-s);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  background: var(--ds-color-surface-raised);
  border: 1px solid var(--ds-color-border);
  border-radius: 50%;
  color: var(--ds-color-text-weak);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: var(--textarea-transition);
}

.c-textarea__clear.is-visible {
  opacity: 1;
  visibility: visible;
}

.c-textarea__clear:hover {
  background: var(--ds-color-status-danger-subtle);
  border-color: var(--ds-color-status-danger);
  color: var(--ds-color-status-danger);
}

.c-textarea__clear:focus-visible {
  outline: var(--textarea-focus-ring-width) solid var(--textarea-focus-ring-color);
  outline-offset: 1px;
}

/* ========================================
   Footer
   ======================================== */

.c-textarea__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--ds-space-m);
  padding-top: var(--ds-space-xs);
  font-size: var(--textarea-counter-font-size);
  color: var(--textarea-counter-color);
}

.c-textarea__autosave-indicator {
  display: flex;
  align-items: center;
  gap: var(--ds-space-xs);
  color: var(--ds-color-text-weakest);
  font-size: var(--ds-font-size-xs);
}

.c-textarea__autosave-indicator svg {
  opacity: 0.6;
}

.c-textarea__autosave-indicator.is-saving {
  color: var(--ds-color-status-info);
}

.c-textarea__autosave-indicator.is-saved {
  color: var(--ds-color-status-success);
}



/* ========================================
   Focused State Enhancement
   ======================================== */

.c-textarea--focused .c-textarea__toolbar {
  border-color: var(--textarea-border-color-focus);
}

/* ========================================
   With Clearable Modifier
   ======================================== */

.c-textarea--clearable .c-textarea__field {
  padding-right: 2.5rem;
}

/* ========================================
   Underlined Variant
   ======================================== */

.c-textarea--underlined .c-textarea__field {
  border-radius: 0;
  border-top: none;
  border-left: none;
  border-right: none;
  border-bottom-width: 2px;
  background: transparent;
  padding-left: 0;
  padding-right: 0;
}

.c-textarea--underlined .c-textarea__field:focus {
  box-shadow: none;
}

/* ========================================
   Ghost Variant
   ======================================== */

.c-textarea--ghost .c-textarea__field {
  background: transparent;
  border-color: transparent;
}

.c-textarea--ghost .c-textarea__field:hover:not(:disabled) {
  background: var(--ds-color-surface-hover);
  border-color: transparent;
}

.c-textarea--ghost .c-textarea__field:focus:not(:disabled) {
  background: var(--ds-color-surface);
  border-color: var(--textarea-border-color-focus);
}

/* ========================================
   Monospace Variant (for code)
   ======================================== */

.c-textarea--monospace .c-textarea__field {
  font-family: var(--ds-font-family-mono, 'SF Mono', 'Consolas', 'Monaco', monospace);
  font-size: var(--ds-font-size-s);
  line-height: 1.6;
  tab-size: 2;
}

/* ========================================
   Bordered Variant
   ======================================== */

.c-textarea--bordered .c-textarea__wrapper {
  padding: var(--ds-space-xs);
  background: var(--ds-color-surface-raised);
  border: var(--textarea-border-width) solid var(--textarea-border-color);
  border-radius: var(--textarea-border-radius);
}

.c-textarea--bordered .c-textarea__field {
  border: none;
  background: var(--ds-color-surface);
  border-radius: calc(var(--textarea-border-radius) - 2px);
}

.c-textarea--bordered .c-textarea__field:focus {
  box-shadow: none;
}

.c-textarea--bordered:focus-within .c-textarea__wrapper {
  border-color: var(--textarea-border-color-focus);
  box-shadow: 0 0 0 var(--textarea-focus-ring-width) rgba(13, 86, 150, 0.2);
}

/* ========================================
   Counter Styles in Footer
   ======================================== */

.c-textarea__footer .c-textarea__counter {
  margin-top: 0;
  margin-left: auto;
}

/* ========================================
   Word Count Display
   ======================================== */

.c-textarea__word-count {
  font-size: var(--textarea-counter-font-size);
  color: var(--textarea-counter-color);
}

/* ========================================
   Disabled State for Toolbar
   ======================================== */

.c-textarea--disabled .c-textarea__toolbar {
  opacity: 0.6;
  pointer-events: none;
}

.c-textarea--disabled .c-textarea__toolbar-btn {
  cursor: not-allowed;
}

/* ========================================
   Compact Mode
   ======================================== */

.c-textarea--compact .c-textarea__label {
  font-size: var(--ds-font-size-xs);
}

.c-textarea--compact .c-textarea__field {
  min-height: var(--textarea-min-height-xs);
  padding: var(--textarea-padding-y-xs) var(--textarea-padding-x-xs);
  font-size: var(--textarea-font-size-s);
}

.c-textarea--compact .c-textarea__toolbar {
  padding: var(--ds-space-2xs) var(--ds-space-xs);
}

.c-textarea--compact .c-textarea__toolbar-btn {
  width: 1.5rem;
  height: 1.5rem;
}

.c-textarea--compact .c-textarea__toolbar-btn svg {
  width: 12px;
  height: 12px;
}
