/* =====================================================
   EMR ŞAHİN GROUP — Inputs & Form Elements
   ===================================================== */

/* ── Form Grubu ── */
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

/* ── Label ── */
.form-label {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  letter-spacing: 0.3px;
}

/* ── Temel Input ── */
.input {
  width: 100%;
  padding: 11px 14px;
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  outline: none;
  transition:
    border-color var(--transition-fast),
    box-shadow   var(--transition-fast),
    background   var(--transition-fast);
  -webkit-appearance: none;
}

.input::placeholder { color: var(--color-text-placeholder); }

.input:hover:not(:disabled) {
  border-color: rgba(108, 99, 255, 0.3);
  background: var(--color-surface-2);
}

.input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.2);
  background: var(--color-surface-2);
}

.input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  user-select: none;
}

/* ── Boyutlar ── */
.input-sm {
  padding: 8px 12px;
  font-size: var(--font-size-xs);
  border-radius: var(--radius-sm);
}

.input-lg {
  padding: 14px 18px;
  font-size: var(--font-size-md);
  border-radius: var(--radius-lg);
}

/* ── Durum Varyantları ── */
.input-success {
  border-color: var(--color-success);
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
}
.input-success:focus {
  border-color: var(--color-success);
  box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.25);
}

.input-error {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15);
}
.input-error:focus {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.25);
}

/* ── Yardımcı Metin ── */
.form-hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
}
.form-hint.error { color: #F87171; }
.form-hint.success { color: #4ADE80; }

/* ── Icon ile Input ── */
.input-wrapper {
  position: relative;
  width: 100%;
}

.input-wrapper .input-icon {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-placeholder);
  pointer-events: none;
  transition: color var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.input-wrapper .input-icon-left  { left: 12px; }
.input-wrapper .input-icon-right { right: 12px; }

.input-wrapper .input.has-icon-left  { padding-left: 40px; }
.input-wrapper .input.has-icon-right { padding-right: 40px; }

.input-wrapper:focus-within .input-icon { color: var(--color-primary-light); }

/* Şifre göster/gizle butonu */
.input-wrapper .input-action {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--color-text-placeholder);
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast);
  display: flex;
}
.input-wrapper .input-action:hover { color: var(--color-primary-light); }

/* ── Textarea ── */
.textarea {
  width: 100%;
  min-height: 110px;
  padding: 12px 14px;
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  background: var(--color-surface);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  outline: none;
  resize: vertical;
  line-height: 1.6;
  transition:
    border-color var(--transition-fast),
    box-shadow   var(--transition-fast),
    background   var(--transition-fast);
}
.textarea::placeholder { color: var(--color-text-placeholder); }
.textarea:hover:not(:disabled) {
  border-color: rgba(108, 99, 255, 0.3);
  background: var(--color-surface-2);
}
.textarea:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.2);
  background: var(--color-surface-2);
}

/* ── Select ── */
.select {
  width: 100%;
  padding: 11px 36px 11px 14px;
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  color: var(--color-text);
  background: var(--color-surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right 12px center;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  transition:
    border-color var(--transition-fast),
    box-shadow   var(--transition-fast),
    background-color var(--transition-fast);
}
.select:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(108, 99, 255, 0.2);
}

/* ── Checkbox & Radio ── */
.check-group {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  cursor: pointer;
  user-select: none;
}

.check-group input[type="checkbox"],
.check-group input[type="radio"] {
  width: 18px;
  height: 18px;
  accent-color: var(--color-primary);
  cursor: pointer;
  flex-shrink: 0;
}

.check-group span {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.check-group:hover span { color: var(--color-text); }
