/**
 * @copyright Stevie-Ray
 * Input Components - shadcn/ui inspired
 */
/**
 * @copyright Stevie-Ray
 * Global Color System - Neutral Palette
 * CSS Custom Properties for consistent theming
 */
/* ===========================================
   CSS CUSTOM PROPERTIES - ROOT
   =========================================== */
:root {
  /* Neutral Color Palette */
  --neutral: #ffffff;
  --neutral-50: #fafafa;
  --neutral-100: #f5f5f5;
  --neutral-200: #e5e5e5;
  --neutral-300: #d4d4d4;
  --neutral-400: #a3a3a3;
  --neutral-500: #737373;
  --neutral-600: #525252;
  --neutral-700: #404040;
  --neutral-800: #262626;
  --neutral-900: #171717;
  --neutral-950: #0a0a0a;
  /* Semantic Color Mappings */
  --background: var(--neutral-50);
  --foreground: var(--neutral-900);
  --muted: var(--neutral-100);
  --muted-foreground: var(--neutral-600);
  --border: var(--neutral-200);
  --input: var(--neutral-100);
  --ring: var(--neutral-400);
  /* Brand Colors */
  --primary: hsl(221.2 83.2% 53.3%);
  --primary-foreground: hsl(210 40% 98%);
  --secondary: var(--neutral-100);
  --secondary-foreground: var(--neutral-900);
  --accent: var(--neutral-100);
  --accent-foreground: var(--neutral-900);
  /* Status Colors */
  --destructive: #FF80AB;
  --destructive-foreground: #000000;
  --success: #CCFF90;
  --success-foreground: #000000;
  --warning: #FFAB40;
  --warning-foreground: #000000;
  --info: #82B1FF;
  --info-foreground: #000000;
  /* Sidebar Specific Colors */
  --sidebar-bg: var(--neutral-50);
  --sidebar-border: var(--neutral-200);
  --sidebar-foreground: var(--neutral-900);
  --sidebar-muted: var(--neutral-600);
  --sidebar-accent: var(--neutral-100);
  --sidebar-accent-foreground: var(--neutral-900);
  --sidebar-hover: var(--neutral-100);
  --sidebar-active-bg: var(--neutral-100);
  --sidebar-active-foreground: var(--neutral-900);
}

/* ===========================================
   SCSS VARIABLES FOR BACKWARDS COMPATIBILITY
   =========================================== */
input, textarea {
  font-family: inherit;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: #171717;
}

input[type=text],
input[type=email],
input[type=password],
input[type=number],
input[type=tel],
input[type=url],
input[type=search],
input[type=date],
input[type=datetime-local],
input[type=month],
input[type=time],
input[type=week] {
  display: flex;
  height: 2rem;
  border-radius: 0.375rem;
  border: 1px solid #e5e5e5;
  background-color: #fafafa;
  padding: 0.375rem 0.75rem;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: text;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=password]::placeholder,
input[type=number]::placeholder,
input[type=tel]::placeholder,
input[type=url]::placeholder,
input[type=search]::placeholder,
input[type=date]::placeholder,
input[type=datetime-local]::placeholder,
input[type=month]::placeholder,
input[type=time]::placeholder,
input[type=week]::placeholder {
  color: #525252;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=password]:focus,
input[type=number]:focus,
input[type=tel]:focus,
input[type=url]:focus,
input[type=search]:focus,
input[type=date]:focus,
input[type=datetime-local]:focus,
input[type=month]:focus,
input[type=time]:focus,
input[type=week]:focus {
  outline: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  border-color: #a3a3a3;
}
input[type=text]:disabled,
input[type=email]:disabled,
input[type=password]:disabled,
input[type=number]:disabled,
input[type=tel]:disabled,
input[type=url]:disabled,
input[type=search]:disabled,
input[type=date]:disabled,
input[type=datetime-local]:disabled,
input[type=month]:disabled,
input[type=time]:disabled,
input[type=week]:disabled {
  cursor: not-allowed;
  opacity: 0.5;
  background-color: #f5f5f5;
  color: #525252;
}
input[type=text]:read-only,
input[type=email]:read-only,
input[type=password]:read-only,
input[type=number]:read-only,
input[type=tel]:read-only,
input[type=url]:read-only,
input[type=search]:read-only,
input[type=date]:read-only,
input[type=datetime-local]:read-only,
input[type=month]:read-only,
input[type=time]:read-only,
input[type=week]:read-only {
  background-color: #f5f5f5;
}

textarea {
  display: flex;
  width: 100%;
  min-height: 80px;
  border-radius: 0.375rem;
  border: 1px solid #e5e5e5;
  background-color: #fafafa;
  padding: 0.375rem 0.75rem;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: text;
  resize: vertical;
  font-family: inherit;
}
textarea::placeholder {
  color: #525252;
}
textarea:focus {
  outline: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  border-color: #a3a3a3;
}
textarea:disabled {
  cursor: not-allowed;
  opacity: 0.5;
  background-color: #f5f5f5;
  color: #525252;
  resize: none;
}
textarea:read-only {
  background-color: #f5f5f5;
}

.input-sm, .textarea-sm {
  height: 1.75rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
  line-height: 1rem;
}

.input-md, .textarea-md {
  height: 2rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.input-lg, .textarea-lg {
  height: 2.5rem;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  line-height: 1.5rem;
}

.input-valid {
  border-color: #CCFF90;
}
.input-valid:focus {
  border-color: #CCFF90;
  box-shadow: 0 2px 4px rgba(34, 197, 94, 0.2);
}

.input-invalid {
  border-color: #FF80AB;
}
.input-invalid:focus {
  border-color: #FF80AB;
  box-shadow: 0 2px 4px rgba(239, 68, 68, 0.2);
}

.input-full-width {
  width: 100%;
}

.input-group {
  display: flex;
  width: 100%;
  position: relative;
}

.input-with-addon {
  display: flex;
  align-items: stretch;
  width: 100%;
}
.input-with-addon .input-addon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.75rem;
  height: 2rem;
  background-color: #f5f5f5;
  border: 1px solid #e5e5e5;
  color: #171717;
  font-size: 0.875rem;
  white-space: nowrap;
  user-select: none;
}
.input-with-addon .input-addon:first-child {
  border-top-left-radius: 0.375rem;
  border-bottom-left-radius: 0.375rem;
  border-right: none;
}
.input-with-addon .input-addon:last-child {
  border-top-right-radius: 0.375rem;
  border-bottom-right-radius: 0.375rem;
  border-left: none;
}
.input-with-addon .input-field {
  flex: 1;
  border-radius: 0;
  height: 2rem;
}
.input-with-addon .input-field:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}
.input-with-addon .input-field:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.input-addon.prefix {
  margin-right: -1px;
}

.input-addon.suffix {
  margin-left: -1px;
}

.input-addon.icon {
  width: 2.5rem;
  padding: 0;
}
.input-addon.icon svg {
  width: 1rem;
  height: 1rem;
}

.input-addon.button {
  background-color: hsl(221.2, 83.2%, 53.3%);
  color: hsl(210, 40%, 98%);
  border-color: hsl(221.2, 83.2%, 53.3%);
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.input-addon.button:hover {
  background-color: hsla(221.2, 83.2%, 53.3%, 0.9);
}
.input-addon.button:disabled {
  background-color: #f5f5f5;
  color: #525252;
  cursor: not-allowed;
}

.input-group-sm .input-addon {
  height: 1.75rem;
  padding: 0 0.5rem;
  font-size: 0.75rem;
}
.input-group-sm .input-addon.icon {
  width: 2rem;
}
.input-group-sm .input-field {
  height: 1.75rem;
}

.input-group-md .input-addon {
  height: 2rem;
  padding: 0 0.75rem;
  font-size: 0.875rem;
}
.input-group-md .input-addon.icon {
  width: 2.5rem;
}
.input-group-md .input-field {
  height: 2rem;
}

.input-group-lg .input-addon {
  height: 2.5rem;
  padding: 0 1rem;
  font-size: 1rem;
}
.input-group-lg .input-addon.icon {
  width: 3rem;
}
.input-group-lg .input-field {
  height: 2.5rem;
}

.input-floating {
  position: relative;
}
.input-floating .input-field {
  padding-top: 1rem;
  padding-bottom: 0.5rem;
}
.input-floating .input-label {
  position: absolute;
  top: 50%;
  left: 0.75rem;
  transform: translateY(-50%);
  transition: all 0.2s ease-in-out;
  color: #525252;
  pointer-events: none;
  font-size: 0.875rem;
}
.input-floating .input-field:focus + .input-label,
.input-floating .input-field:not(:placeholder-shown) + .input-label {
  top: 0.5rem;
  left: 0.75rem;
  font-size: 0.75rem;
  color: #a3a3a3;
}

.input-group-valid .input-addon {
  border-color: #CCFF90;
}
.input-group-valid .input-addon:first-child {
  border-right-color: #CCFF90;
}
.input-group-valid .input-addon:last-child {
  border-left-color: #CCFF90;
}
.input-group-valid .input-field {
  border-color: #CCFF90;
}
.input-group-valid .input-field:focus {
  border-color: #CCFF90;
  box-shadow: 0 2px 4px rgba(34, 197, 94, 0.2);
}

.input-group-invalid .input-addon {
  border-color: #FF80AB;
}
.input-group-invalid .input-addon:first-child {
  border-right-color: #FF80AB;
}
.input-group-invalid .input-addon:last-child {
  border-left-color: #FF80AB;
}
.input-group-invalid .input-field {
  border-color: #FF80AB;
}
.input-group-invalid .input-field:focus {
  border-color: #FF80AB;
  box-shadow: 0 2px 4px rgba(239, 68, 68, 0.2);
}

input[type=file] {
  display: block;
  width: 100%;
  padding: 0;
  border: none;
  background: transparent;
}
input[type=file]:focus {
  outline: none;
}
input[type=file]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

select {
  appearance: none;
  display: block;
  height: 2rem;
  padding: 0.375rem 2.75rem 0.375rem 0.75rem;
  font-size: 0.875rem;
  font-family: inherit;
  line-height: 1.25rem;
  color: #171717;
  background-color: #fafafa;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%230f172a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M6 9l6 6l6 -6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 16px;
  border: 1px solid #e5e5e5;
  border-radius: 0.375rem;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}
select:focus {
  outline: none;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  border-color: #a3a3a3;
}
select:disabled {
  cursor: not-allowed;
  opacity: 0.5;
  background-color: #f5f5f5;
  color: #525252;
}

@media (max-width: 768px) {
  .input-group {
    flex-direction: column;
  }
  .input-group .input-addon {
    width: 100%;
    border-radius: 0.375rem;
    margin: 0;
  }
  .input-group .input-addon:first-child, .input-group .input-addon:last-child {
    border-radius: 0.375rem;
  }
  .input-group .input-field {
    border-radius: 0.375rem;
    margin: 0;
  }
}

/*# sourceMappingURL=input.css.map */
