/**
 * Nova 유틸리티 클래스 (텍스트, 배경, 진행바, 링크, 탭, 페이지네이션, 드롭다운 등)
 * Bootstrap/AdminLTE 호환 오버라이드 포함
 */

/* === 텍스트 유틸리티 === */
.tw-app .text-muted   { color: var(--color-gray-500); }
.tw-app .text-danger  { color: var(--color-danger); }
.tw-app .text-success { color: var(--color-success); }
.tw-app .text-warning { color: var(--color-warning); }
.tw-app .text-info    { color: var(--color-info); }
.tw-app .text-primary { color: var(--color-primary-500); }

/* === 배경 유틸리티 === */
.tw-app .bg-success   { background: var(--color-success); }
.tw-app .bg-warning   { background: var(--color-warning); }
.tw-app .bg-danger    { background: var(--color-danger); }
.tw-app .bg-info      { background: var(--color-info); }
.tw-app .bg-secondary { background: var(--color-gray-500); }

/* === Progress bar === */
.tw-app .progress {
	background: var(--color-gray-200);
	border-radius: 4px;
}
.tw-app .progress-bar.bg-success { background: var(--color-success); }
.tw-app .progress-bar.bg-warning { background: var(--color-warning); }
.tw-app .progress-bar.bg-danger  { background: var(--color-danger); }
.tw-app .progress-bar.bg-info    { background: var(--color-primary-500); }

/* === Code 태그 === */
.tw-app code {
	background: var(--color-gray-100);
	color: var(--color-danger);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: var(--font-size-label);
}

/* === 링크 === */
.tw-app a { color: var(--color-primary-500); }
.tw-app a:hover { color: var(--color-primary-700); text-decoration: none; }

/* === nav-tabs === */
.tw-app .nav-tabs { border-bottom-color: var(--color-gray-200); }
.tw-app .nav-tabs .nav-link { color: var(--color-gray-500); border: none; }
.tw-app .nav-tabs .nav-link.active {
	color: var(--color-primary-500);
	background: transparent;
	border-bottom: 2px solid var(--color-primary-500);
	font-weight: 600;
}
.tw-app .nav-tabs .nav-link:hover { color: var(--color-gray-900); }

/* === Nova 탭 (커스텀) === */
.nova-tab-group { display: flex; gap: 4px; margin-bottom: 16px; flex-wrap: wrap; }
.nova-tab {
	padding: 8px 16px;
	border-radius: var(--radius-md);
	background: var(--color-gray-100);
	color: var(--color-gray-500);
	border: none;
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--motion-fast);
}
.nova-tab:hover { background: var(--color-gray-200); color: var(--color-gray-700); }
.nova-tab.active { background: var(--color-primary-500); color: #fff; }

/* === Pagination (Bootstrap) === */
.tw-app .pagination .page-link,
.tw-app .pagination-sm .page-link {
	background: var(--color-surface);
	border-color: var(--color-gray-200);
	color: var(--color-gray-700);
	border-radius: var(--radius-md);
}
.tw-app .pagination .page-item.active .page-link,
.tw-app .pagination-sm .page-item.active .page-link {
	background: var(--color-primary-500);
	border-color: var(--color-primary-500);
	color: #fff;
}
.tw-app .pagination .page-link:hover,
.tw-app .pagination-sm .page-link:hover {
	background: var(--color-gray-100);
	color: var(--color-gray-900);
}

/* === Paging (커스텀 ._pagination) === */
.tw-app ._pagination { list-style: none; margin: 0 auto; padding: 0; display: flex; justify-content: center; gap: 4px; }
.tw-app ._pagination li { display: inline-block; }
.tw-app ._pagination li > a {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 32px; min-height: 32px; padding: 0 10px;
	border: 1px solid var(--color-gray-200); border-radius: var(--radius-md);
	background: var(--color-surface); color: var(--color-gray-700);
	font-size: 13px; text-decoration: none; transition: all var(--motion-fast);
}
.tw-app ._pagination li > a:hover { background: var(--color-gray-100); color: var(--color-gray-900); }
.tw-app ._pagination li.active > a {
	background: var(--color-primary-500);
	border-color: var(--color-primary-500);
	color: #fff; font-weight: 600;
}
.tw-app ._pagination li.disabled > a { opacity: 0.4; cursor: not-allowed; }

/* === Dropdown === */
.tw-app .dropdown-menu {
	background: var(--color-surface);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-md);
}
.tw-app .dropdown-item { color: var(--color-gray-700); transition: background var(--motion-fast); }
.tw-app .dropdown-item:hover { background: var(--color-primary-50); color: var(--color-gray-900); }
.tw-app .dropdown-item i { width: 18px; margin-right: 8px; color: var(--color-gray-500); }

/* === Callout (page_top) === */
.tw-app .callout,
.tw-app .callout-info {
	background: var(--color-primary-50);
	border-color: var(--color-primary-500);
	border-left: 4px solid var(--color-primary-500);
	color: var(--color-gray-700);
	border-radius: var(--radius-md);
}

/* === Page title === */
.tw-app .content-header h1 {
	color: var(--color-gray-900);
	font-size: var(--font-size-page-title);
	font-weight: var(--font-weight-page-title);
}

/* === Layout overrides === */
.tw-app .main-header { display: none !important; }
body.sidebar-mini .content-wrapper { margin-left: 0; }


/* === Action Button (공통) === */
.nova-action-group { text-align: center; }
.nova-action-btn {
	width: 32px; height: 32px;
	border: none; background: transparent;
	color: var(--color-gray-500);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all var(--motion-fast);
}
.nova-action-btn:hover {
	background: var(--color-primary-50);
	color: var(--color-primary-500);
}

/* === Empty State (공통) === */
.nova-empty { padding: 48px 16px !important; text-align: center; }
.nova-empty-inner { color: var(--color-gray-500); }
.nova-empty-inner i { font-size: 48px; color: var(--color-gray-300); margin-bottom: 12px; display: block; }
.nova-empty-inner p { font-size: var(--font-size-body); margin: 0; }

/* === Stat Row (공통) === */
.nova-stat-row {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 10px;
	margin-bottom: 12px;
}
@media (max-width: 1023px) { .nova-stat-row { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) { .nova-stat-row { grid-template-columns: 1fr; } }


/* === 전역 기본 텍스트 색상 (body/루트) === */
.tw-app {
	color: var(--color-gray-700);
}
.tw-app body,
body.tw-app,
.tw-app p,
.tw-app span,
.tw-app div,
.tw-app li,
.tw-app label {
	color: inherit;
}
/* AdminLTE body color override */
body {
	color: var(--color-gray-700) !important;
}
/* h1~h6 제목 */
.tw-app h1, .tw-app h2, .tw-app h3, .tw-app h4, .tw-app h5, .tw-app h6 {
	color: var(--color-gray-900);
}
/* small, .small */
.tw-app small, .tw-app .small {
	color: var(--color-gray-500);
}


/* === ApexCharts 다크 테마 텍스트 강제 오버라이드 === */
.tw-app .apexcharts-text,
.tw-app .apexcharts-xaxis-label,
.tw-app .apexcharts-yaxis-label {
	fill: var(--color-gray-500) !important;
}
.tw-app .apexcharts-title-text {
	fill: var(--color-gray-900) !important;
}
.tw-app .apexcharts-legend-text {
	color: var(--color-gray-700) !important;
}
.tw-app .apexcharts-gridline {
	stroke: var(--color-gray-200) !important;
}
.tw-app .apexcharts-xaxis line,
.tw-app .apexcharts-yaxis line {
	stroke: var(--color-gray-200) !important;
}
/* 툴팁 */
.tw-app .apexcharts-tooltip {
	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;
	box-shadow: var(--shadow-md) !important;
}
.tw-app .apexcharts-tooltip-title {
	background: var(--color-surface-deeper) !important;
	border-bottom: 1px solid var(--color-gray-200) !important;
	color: var(--color-gray-900) !important;
}
.tw-app .apexcharts-tooltip-series-group {
	color: var(--color-gray-700) !important;
}
/* 데이터 라벨 */
.tw-app .apexcharts-datalabel {
	fill: var(--color-gray-700) !important;
}




/* === 헤더 배경: 사이드바와 동일한 짙은 톤 통일 (라이트/다크 공통) === */
.nova-header {
	background: var(--color-sidebar-bg) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
}


/* === 모바일 사이드바 + 헤더 반응형 === */
@media (max-width: 1023px) {
	.nova-sidebar {
		transform: translateX(-100%);
		transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1);
	}
	body.nova-sidebar-open .nova-sidebar {
		transform: translateX(0);
		box-shadow: 4px 0 20px rgba(0, 0, 0, 0.4);
	}
	/* 오버레이 */
	body.nova-sidebar-open::after {
		content: '';
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, 0.4);
		z-index: 1037;
	}
	/* 헤더: 모바일에서 전체 너비 + 좌측 패딩 리셋 */
	.nova-header {
		left: 0 !important;
		padding-left: 16px !important;
	}
	/* 콘텐츠: 모바일에서 margin 제거 */
	.nova-content {
		margin-left: 0 !important;
	}
}


/* === 모바일 헤더 햄버거 버튼 강제 표시 === */
@media (max-width: 1023px) {
	.nova-header-hamburger {
		display: flex !important;
		width: 36px;
		height: 36px;
		align-items: center;
		justify-content: center;
		border-radius: 8px;
		color: #9ca3af;
		text-decoration: none;
		transition: all 120ms;
		background: none;
		border: none;
	}
	.nova-header-hamburger:hover {
		background: rgba(255,255,255,0.06);
		color: #fff;
	}
	.nova-header {
		left: 0 !important;
		padding-left: 16px !important;
		background: var(--color-sidebar-bg) !important;
		border-bottom: 1px solid rgba(255, 255, 255, 0.06) !important;
	}
}


/* === 데스크탑 사이드바 미니(접힘) 모드 — 아이콘만 표시 === */
@media (min-width: 1024px) {
	.nova-sidebar {
		transition: width 200ms cubic-bezier(0.4, 0, 0.2, 1);
	}
	body.nova-sidebar-collapsed .nova-sidebar {
		width: 64px;
	}
	body.nova-sidebar-collapsed .nova-content {
		margin-left: 64px;
	}
	/* 텍스트/검색/버튼 숨김 — 아이콘만 노출 */
	body.nova-sidebar-collapsed .nova-brand-name,
	body.nova-sidebar-collapsed .nova-sidebar-brand-refresh,
	body.nova-sidebar-collapsed .nova-sidebar-search,
	body.nova-sidebar-collapsed .nova-fav-header span,
	body.nova-sidebar-collapsed .nova-fav-link-text,
	body.nova-sidebar-collapsed .nova-fav-remove,
	body.nova-sidebar-collapsed .nova-nav-group-text,
	body.nova-sidebar-collapsed .nova-nav-arrow,
	body.nova-sidebar-collapsed .nova-nav-text,
	body.nova-sidebar-collapsed .nova-fav-btn {
		display: none !important;
	}
	/* 브랜드 로고 중앙 정렬 */
	body.nova-sidebar-collapsed .nova-sidebar-brand {
		justify-content: center !important;
		padding: 0 !important;
	}
	body.nova-sidebar-collapsed .nova-sidebar-brand-text {
		flex: 0 0 auto !important;
		justify-content: center !important;
	}
	body.nova-sidebar-collapsed .nova-brand-logo-wrap {
		width: 26px !important;
		height: 26px !important;
	}
	body.nova-sidebar-collapsed .nova-fav-header {
		justify-content: center !important;
		padding: 6px 0 4px !important;
	}
	body.nova-sidebar-collapsed .nova-nav-group-header {
		justify-content: center !important;
		padding: 10px 0 4px !important;
	}
	body.nova-sidebar-collapsed .nova-nav-link,
	body.nova-sidebar-collapsed .nova-fav-link {
		justify-content: center !important;
		padding: 8px 0 !important;
		border-left-color: transparent !important;
	}
	body.nova-sidebar-collapsed .nova-nav-icon,
	body.nova-sidebar-collapsed .nova-fav-link-icon,
	body.nova-sidebar-collapsed .nova-nav-group-header .nova-nav-icon {
		margin-right: 0 !important;
	}
}


/* === 사이드바 닫기 버튼 (모바일만 표시) === */
.nova-sidebar-close {
	display: none;
	cursor: pointer;
	padding: 6px 8px;
	color: rgba(255, 255, 255, 0.5);
	border-radius: 6px;
	transition: all 120ms;
}
.nova-sidebar-close:hover {
	color: #fff;
	background: rgba(255, 255, 255, 0.06);
}
@media (max-width: 1023px) {
	.nova-sidebar-close {
		display: block;
	}
}




/* === 드롭다운이 카드 밖으로 넘칠 수 있도록 (데스크탑) === */
@media (min-width: 1200px) {
	.tw-app .card,
	.tw-app .nova-card {
		overflow: visible !important;
	}
	.tw-app .card-body {
		overflow: visible !important;
	}
}
/* 모바일에서도 드롭다운 정상 표시 */
.tw-app .dropdown-menu {
	z-index: 1050;
}

/* body에 append된 드롭다운도 다크 테마 적용 (initTableDropdownFix 사용 시) */
body > .dropdown-menu {
	background: var(--color-surface);
	border: 1px solid var(--color-gray-200);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	padding: 6px 0;
	min-width: 160px;
}
body > .dropdown-menu .dropdown-item {
	color: var(--color-gray-700);
	padding: 8px 16px;
	font-size: 13px;
	cursor: pointer;
	transition: background 120ms;
}
body > .dropdown-menu .dropdown-item:hover {
	background: var(--color-primary-50);
	color: var(--color-gray-900);
}
body > .dropdown-menu .dropdown-item i {
	width: 18px;
	margin-right: 8px;
	color: var(--color-gray-500);
}
