/**
 * TopCalc 입력 필드 컴포넌트 - PC 웹
 *
 * 입력 필드 스타일 정의:
 * - .input-field    : 기본 텍스트 입력
 * - .input-number   : 숫자 전용 (monospace)
 * - .input-select   : 셀렉트 박스
 * - .input-group    : 입력 + 라벨 + 힌트 묶음
 * - .input-addon    : 단위 표시 (원, %, 개월)
 * - .input-checkbox : 체크박스
 * - .input-radio    : 라디오 버튼
 * - .input-range    : 슬라이더
 *
 * @version 1.0.0
 * @date 2026-05-25
 */

/* ==============================================
   입력 그룹 (.input-group)
   ============================================== */
.input-group {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
}

/* 라벨 */
.input-group__label {
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--gray-700);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

/* 필수 표시 */
.input-group__label--required::after {
    content: '*';
    color: var(--error-500);
    font-weight: var(--font-bold);
}

/* 힌트 텍스트 */
.input-group__hint {
    font-size: var(--text-xs);
    color: var(--gray-400);
    line-height: var(--leading-normal);
}

/* 에러 메시지 */
.input-group__error {
    font-size: var(--text-xs);
    color: var(--error-500);
    display: flex;
    align-items: center;
    gap: var(--space-1);
}

.input-group__error::before {
    content: '\26A0';
    font-size: var(--text-sm);
}


/* ==============================================
   기본 입력 필드 (.input-field)
   ============================================== */
.input-field {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-md);
    font-family: var(--font-primary);
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    color: var(--gray-800);
    background: var(--bg-white);
    transition: all var(--transition-base);
    appearance: none;
    -webkit-appearance: none;
}

.input-field::placeholder {
    color: var(--gray-400);
}

/* 호버 상태 */
.input-field:hover {
    border-color: var(--gray-400);
}

/* 포커스 상태 */
.input-field:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

/* 에러 상태 */
.input-field--error {
    border-color: var(--error-500);
}

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

/* 성공 상태 */
.input-field--success {
    border-color: var(--success-500);
}

.input-field--success:focus {
    border-color: var(--success-500);
    box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.15);
}

/* 비활성 상태 */
.input-field:disabled {
    background: var(--gray-100);
    border-color: var(--gray-200);
    color: var(--gray-400);
    cursor: not-allowed;
}

/* 읽기 전용 */
.input-field:read-only {
    background: var(--gray-50);
    border-color: var(--gray-200);
    cursor: default;
}

/* 크기 변형 */
.input-field--sm {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
}

.input-field--lg {
    padding: var(--space-4) var(--space-5);
    font-size: var(--text-lg);
}


/* ==============================================
   숫자 전용 입력 (.input-number)
   ============================================== */
.input-number {
    font-family: var(--font-mono);
    text-align: right;
    letter-spacing: var(--tracking-wide);
    font-variant-numeric: tabular-nums;
}

/* 숫자 입력 스피너 제거 */
.input-number::-webkit-outer-spin-button,
.input-number::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.input-number[type="number"] {
    -moz-appearance: textfield;
}


/* ==============================================
   단위 표시 애드온 (.input-addon)
   ============================================== */
.input-with-addon {
    display: flex;
    align-items: stretch;
    position: relative;
}

.input-with-addon .input-field {
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    border-right: none;
}

.input-addon {
    display: flex;
    align-items: center;
    padding: 0 var(--space-4);
    background: var(--gray-100);
    border: 2px solid var(--gray-300);
    border-left: none;
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--gray-500);
    white-space: nowrap;
    transition: all var(--transition-base);
}

/* 포커스 시 애드온 보더도 변경 */
.input-with-addon:focus-within .input-field {
    border-color: var(--primary-500);
}

.input-with-addon:focus-within .input-addon {
    border-color: var(--primary-500);
    color: var(--primary-600);
    background: var(--primary-50);
}

/* 왼쪽 애드온 */
.input-addon--left {
    order: -1;
    border-radius: var(--radius-md) 0 0 var(--radius-md);
    border-right: none;
    border-left: 2px solid var(--gray-300);
}

.input-addon--left + .input-field {
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    border-left: none;
    border-right: 2px solid var(--gray-300);
}


/* ==============================================
   셀렉트 박스 (.input-select)
   ============================================== */
.input-select {
    width: 100%;
    padding: var(--space-3) var(--space-10) var(--space-3) var(--space-4);
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-md);
    font-family: var(--font-primary);
    font-size: var(--text-base);
    color: var(--gray-800);
    background-color: var(--bg-white);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236B7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");
    background-position: right var(--space-3) center;
    background-repeat: no-repeat;
    background-size: 20px;
    cursor: pointer;
    transition: all var(--transition-base);
    appearance: none;
    -webkit-appearance: none;
}

.input-select:hover {
    border-color: var(--gray-400);
}

.input-select:focus {
    outline: none;
    border-color: var(--primary-500);
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.15);
}

.input-select:disabled {
    background-color: var(--gray-100);
    color: var(--gray-400);
    cursor: not-allowed;
}


/* ==============================================
   텍스트영역 (.input-textarea)
   ============================================== */
.input-textarea {
    min-height: 120px;
    resize: vertical;
    line-height: var(--leading-relaxed);
}


/* ==============================================
   체크박스 (.input-checkbox)
   ============================================== */
.input-checkbox {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    user-select: none;
}

.input-checkbox__input {
    width: 20px;
    height: 20px;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-sm);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: all var(--transition-fast);
    position: relative;
    flex-shrink: 0;
    background: var(--bg-white);
}

.input-checkbox__input:hover {
    border-color: var(--primary-500);
}

.input-checkbox__input:checked {
    background: var(--primary-500);
    border-color: var(--primary-500);
}

.input-checkbox__input:checked::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 2px;
    width: 6px;
    height: 10px;
    border: solid #FFFFFF;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.input-checkbox__input:focus-visible {
    box-shadow: var(--focus-ring);
}

.input-checkbox__label {
    font-size: var(--text-base);
    color: var(--gray-700);
}


/* ==============================================
   라디오 버튼 (.input-radio)
   ============================================== */
.input-radio {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    cursor: pointer;
    user-select: none;
}

.input-radio__input {
    width: 20px;
    height: 20px;
    border: 2px solid var(--gray-300);
    border-radius: var(--radius-full);
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    transition: all var(--transition-fast);
    position: relative;
    flex-shrink: 0;
    background: var(--bg-white);
}

.input-radio__input:hover {
    border-color: var(--primary-500);
}

.input-radio__input:checked {
    border-color: var(--primary-500);
}

.input-radio__input:checked::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 10px;
    height: 10px;
    border-radius: var(--radius-full);
    background: var(--primary-500);
}

.input-radio__input:focus-visible {
    box-shadow: var(--focus-ring);
}

.input-radio__label {
    font-size: var(--text-base);
    color: var(--gray-700);
}

/* 라디오 그룹 */
.input-radio-group {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

.input-radio-group--vertical {
    flex-direction: column;
    gap: var(--space-3);
}


/* ==============================================
   슬라이더 (.input-range)
   ============================================== */
.input-range-wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.input-range {
    width: 100%;
    height: 6px;
    border-radius: var(--radius-full);
    background: var(--gray-200);
    appearance: none;
    -webkit-appearance: none;
    outline: none;
    cursor: pointer;
}

.input-range::-webkit-slider-thumb {
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border-radius: var(--radius-full);
    background: var(--primary-500);
    border: 3px solid var(--bg-white);
    box-shadow: var(--shadow-md);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.input-range::-webkit-slider-thumb:hover {
    transform: scale(1.2);
    box-shadow: var(--shadow-lg), var(--shadow-primary);
}

.input-range::-moz-range-thumb {
    width: 20px;
    height: 20px;
    border-radius: var(--radius-full);
    background: var(--primary-500);
    border: 3px solid var(--bg-white);
    box-shadow: var(--shadow-md);
    cursor: pointer;
}

/* 슬라이더 값 표시 */
.input-range__value {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--primary-600);
    text-align: center;
}

/* 슬라이더 범위 라벨 */
.input-range__labels {
    display: flex;
    justify-content: space-between;
    font-size: var(--text-xs);
    color: var(--gray-400);
}
