/**
 * Nova 스타일 버튼 공통 클래스
 * design_renewal_2026_06_08 설계 §4.8 참조
 *
 * 주의: 데이터 조작(저장/삭제/등록) 신규 버튼 추가 금지.
 * 기존 페이지의 조작 버튼은 시각 스타일만 본 클래스로 교체한다.
 */

.btn-nova {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 8px 14px;
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	border-radius: var(--radius-md);
	border: 1px solid transparent;
	cursor: pointer;
	transition: background-color var(--motion-fast), color var(--motion-fast),
		border-color var(--motion-fast), box-shadow var(--motion-fast);
	user-select: none;
}

.btn-nova:disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.btn-primary {
	background: var(--color-primary-600);
	color: #fff;
	border-color: var(--color-primary-600);
}
.btn-primary:hover {
	background: var(--color-primary-700);
	border-color: var(--color-primary-700);
}

.btn-secondary {
	background: var(--color-surface);
	color: var(--color-gray-700);
	border-color: var(--color-gray-200);
}
.btn-secondary:hover {
	background: var(--color-gray-100);
}

.btn-danger {
	background: var(--color-danger);
	color: #fff;
	border-color: var(--color-danger);
}
.btn-danger:hover {
	filter: brightness(0.92);
}

.btn-ghost {
	background: transparent;
	color: var(--color-gray-700);
	border-color: transparent;
}
.btn-ghost:hover {
	background: var(--color-gray-100);
}

/* === Bootstrap .btn override (AdminLTE 덮기) === */
.tw-app .btn-primary {
	background: var(--color-primary-600) !important;
	border-color: var(--color-primary-600) !important;
	border-radius: var(--radius-md) !important;
	color: #fff !important;
}
.tw-app .btn-primary:hover {
	background: var(--color-primary-700) !important;
	border-color: var(--color-primary-700) !important;
}
.tw-app .btn-info {
	background: var(--color-primary-500) !important;
	border-color: var(--color-primary-500) !important;
	border-radius: var(--radius-md) !important;
	color: #fff !important;
}
.tw-app .btn-info:hover {
	background: var(--color-primary-600) !important;
	border-color: var(--color-primary-600) !important;
}
.tw-app .btn-secondary,
.tw-app .btn-default {
	background: var(--color-surface) !important;
	border: 1px solid var(--color-gray-200) !important;
	color: var(--color-gray-700) !important;
	border-radius: var(--radius-md) !important;
}
.tw-app .btn-secondary:hover,
.tw-app .btn-default:hover {
	background: var(--color-gray-100) !important;
}
.tw-app .btn-danger {
	background: var(--color-danger) !important;
	border-color: var(--color-danger) !important;
	border-radius: var(--radius-md) !important;
	color: #fff !important;
}
.tw-app .btn-success {
	background: var(--color-success) !important;
	border-color: var(--color-success) !important;
	border-radius: var(--radius-md) !important;
	color: #fff !important;
}
.tw-app .btn-outline-secondary {
	border-color: var(--color-gray-300) !important;
	color: var(--color-gray-700) !important;
	background: transparent !important;
	border-radius: var(--radius-md) !important;
}
.tw-app .btn-outline-secondary:hover {
	background: var(--color-gray-100) !important;
}
.tw-app .btn-outline-primary {
	border-color: var(--color-primary-500) !important;
	color: var(--color-primary-500) !important;
	background: transparent !important;
	border-radius: var(--radius-md) !important;
}
.tw-app .btn-outline-primary:hover {
	background: var(--color-primary-500) !important;
	color: #fff !important;
}
