﻿/* ===== NEWTORANG MAIN PAGE STYLES ===== */
/* Prefix: ntr-main- to avoid conflicts */

/* ===== 디자인 시스템 정의 ===== */
:root {
	/* 색상 */
	--ntr-primary: #c62828;
	--ntr-primary-dark: #b71c1c;
	--ntr-governance: #1a237e;
	--ntr-premium: #00838f;
	/* 텍스트 색상 */
	--ntr-text-dark: #222;
	--ntr-text-base: #333;
	--ntr-text-secondary: #666;
	--ntr-text-muted: #888;
	--ntr-text-light: #999;
	/* 배경/보더 */
	--ntr-bg-light: #f8f8f8;
	--ntr-border: #e5e5e5;
	--ntr-border-light: #f0f0f0;
	/* 폰트 크기 */
	--ntr-font-xs: 12px;
	--ntr-font-sm: 13px;
	--ntr-font-base: 14px;
	--ntr-font-md: 15px;
	--ntr-font-lg: 16px;
	--ntr-font-xl: 18px;
	--ntr-font-2xl: 24px;
	--ntr-font-3xl: 28px;
	--ntr-font-4xl: 32px;
	/* 간격 */
	--ntr-spacing-xs: 4px;
	--ntr-spacing-sm: 8px;
	--ntr-spacing-md: 12px;
	--ntr-spacing-lg: 16px;
	--ntr-spacing-xl: 20px;
	--ntr-spacing-2xl: 24px;
	--ntr-spacing-3xl: 28px;
	/* 둥글기 */
	--ntr-radius-sm: 4px;
	--ntr-radius-md: 8px;
	--ntr-radius-lg: 12px;
}

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: 'Malgun Gothic', -apple-system, BlinkMacSystemFont, sans-serif;
	background-color: #fff;
	color: var(--ntr-text-base);
	line-height: 1.5;
	font-size: var(--ntr-font-base);
}

body, div, input, textarea, button {
	color:#000;
}
/* ===== CONTAINER ===== */
.t_container {
	width: 1200px;
	margin: 0 auto;
	padding: 0;
	position: relative;
	top: 40px;
}

.ntr-main-container {
	width: 890px;
	margin: 0 0 20px;
	padding: 0;
	position: relative;
	float: left;
}

/* ===== HEADER ===== */
.ntr-main-header {
	padding: 0 0 var(--ntr-spacing-xl) 0;
	border-bottom: 1px solid var(--ntr-border);
}

.ntr-main-logo {
	font-size: var(--ntr-font-3xl);
	font-weight: bold;
	color: var(--ntr-primary);
}

.ntr-main-subtitle {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-muted);
	margin-top: var(--ntr-spacing-xs);
}

/* ===== DAILY CHALLENGE SECTION ===== */
.ntr-main-challenge {
	background: var(--ntr-primary);
	padding: var(--ntr-spacing-2xl) var(--ntr-spacing-3xl);
	color: #fff !important;
	margin-top: var(--ntr-spacing-xl);
}

.ntr-main-challenge-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: var(--ntr-spacing-lg);
}

.ntr-main-challenge-title-wrap {
	display: flex;
	align-items: center;
	gap: var(--ntr-spacing-md);
	color:#fff;
}

.ntr-main-challenge-title {
	font-size: var(--ntr-font-xl);
	font-weight: bold;
}

.ntr-main-challenge-btn {
	background: transparent;
	border: 1px solid rgba(255,255,255,0.5);
	color: #fff;
	padding: var(--ntr-spacing-xs) var(--ntr-spacing-md);
	border-radius: var(--ntr-radius-sm);
	font-size: var(--ntr-font-xs);
	cursor: pointer;
	transition: background 0.2s;
}

	.ntr-main-challenge-btn:hover {
		background: rgba(255,255,255,0.1);
	}

.ntr-main-challenge-deadline {
	font-size: var(--ntr-font-base);
	color: rgba(255,255,255,0.8);
}

.ntr-main-challenge-prize-box {
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.3);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-xl) var(--ntr-spacing-2xl);
	margin-bottom: var(--ntr-spacing-xl);
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

.ntr-main-challenge-prize-label {
	font-size: var(--ntr-font-base);
	color: rgba(255,255,255,0.9);
	margin-bottom: var(--ntr-spacing-xs);
}

.ntr-main-challenge-prize {
	font-size: 36px;
	font-weight: bold;
	letter-spacing: -1px;
	color: #fff;
}

.ntr-main-challenge-timer {
	font-size: var(--ntr-font-base);
	color: rgba(255,255,255,0.8);
}

.ntr-main-challenge-cta {
	width: 100%;
	background: #fff;
	color: var(--ntr-primary);
	border: none;
	padding: var(--ntr-spacing-lg);
	border-radius: var(--ntr-radius-md);
	font-size: var(--ntr-font-lg);
	font-weight: bold;
	cursor: pointer;
	transition: background 0.2s;
}

	.ntr-main-challenge-cta:hover {
		background: #f5f5f5;
	}

/* ===== SECTION COMMON ===== */
.ntr-main-section {
	padding: 40px 0;
	border-bottom: 1px solid var(--ntr-border);
}

.ntr-main-section-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 24px;
}

.ntr-main-section-title {
	font-size: var(--ntr-font-xl);
	font-weight: bold;
	color: var(--ntr-text-dark);
}

.ntr-main-section-update {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-light);
}

.ntr-main-view-all {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-muted) !important;
	text-decoration: none;
}

	.ntr-main-view-all:hover {
		color: var(--ntr-primary);
	}

/* ===== MY STATUS SECTION ===== */
.ntr-main-mystatus {
	background: var(--ntr-bg-light);
	padding: var(--ntr-spacing-3xl);
}

.ntr-main-status-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--ntr-spacing-lg);
	margin-bottom: var(--ntr-spacing-lg);
}

.ntr-main-status-card {
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-xl);
}

.ntr-main-status-label {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-muted);
	margin-bottom: var(--ntr-spacing-sm);
}

.ntr-main-status-value {
	font-size: var(--ntr-font-3xl);
	font-weight: bold;
	color: var(--ntr-text-dark);
	display: flex;
	align-items: baseline;
}

.ntr-main-status-rank {
	display: flex;
	align-items: baseline;
}

.ntr-main-status-rank-num {
	font-size: var(--ntr-font-4xl);
	font-weight: bold;
	color: var(--ntr-text-dark);
}

.ntr-main-status-rank-unit {
	font-size: var(--ntr-font-lg);
	font-weight: normal;
	color: var(--ntr-text-secondary);
	margin-left: var(--ntr-spacing-xs);
}

.ntr-main-status-rank-change {
	font-size: var(--ntr-font-base);
	color: var(--ntr-primary);
	margin-left: var(--ntr-spacing-sm);
	font-weight: bold;
}

.ntr-main-status-unit {
	font-size: var(--ntr-font-lg);
	font-weight: normal;
	color: var(--ntr-text-secondary);
	margin-left: 2px;
}

.ntr-main-status-card.horizontal {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ntr-main-status-detail-right {
	font-size: var(--ntr-font-xs);
	color: var(--ntr-text-muted);
	line-height: 1.8;
}

	.ntr-main-status-detail-right span {
		display: block;
	}

.ntr-main-status-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--ntr-spacing-lg);
}

.ntr-main-status-card.wide {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.ntr-main-grade-value {
	font-size: var(--ntr-font-3xl);
	font-weight: bold;
	color: var(--ntr-primary);
}

.ntr-main-grade-link {
	font-size: var(--ntr-font-xs);
	color: var(--ntr-text-muted) !important;
	text-decoration: none;
	border: 1px solid var(--ntr-border);
	padding: 6px var(--ntr-spacing-md);
	border-radius: var(--ntr-radius-sm);
}

	.ntr-main-grade-link:hover {
		background: var(--ntr-bg-light);
	}

/* ===== POPULAR POSTS SECTION ===== */
.ntr-main-post-list {
	list-style: none;
}

.ntr-main-post-item {
	border-bottom: 1px solid var(--ntr-border-light);
}

	.ntr-main-post-item:last-child {
		border-bottom: none;
	}

	.ntr-main-post-item a {
		display: flex;
		align-items: center;
		padding: 14px 0;
		gap: 16px;
		text-decoration: none;
		color: inherit;
	}

.ntr-main-post-badge {
	background: var(--ntr-primary);
	color: #fff;
	font-size: var(--ntr-font-xs);
	font-weight: bold;
	padding: var(--ntr-spacing-xs) 10px;
	border-radius: var(--ntr-radius-sm);
	min-width: 40px;
	text-align: center;
}

.ntr-main-post-content {
	flex: 1;
	min-width: 0;
	display: flex;
	align-items: center;
	gap: var(--ntr-spacing-xl);
}

.ntr-main-post-title {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-base);
	flex: 1;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.ntr-main-post-author {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-secondary);
	width: 100px;
}

.ntr-main-post-stats {
	display: flex;
	gap: var(--ntr-spacing-xl);
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-light);
}

	.ntr-main-post-stats span {
		min-width: 70px;
	}

/* ===== RANKING SECTION ===== */
.ntr-main-ranking-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--ntr-font-base);
}

	.ntr-main-ranking-table thead {
		background: var(--ntr-bg-light);
	}

	.ntr-main-ranking-table th {
		font-weight: 700;
		color: var(--ntr-text-secondary);
		padding: var(--ntr-spacing-md) var(--ntr-spacing-sm);
		text-align: left;
		border-bottom: 1px solid var(--ntr-border);
		font-size: var(--ntr-font-base);
	}

		.ntr-main-ranking-table th:first-child {
			width: 60px;
		}

	.ntr-main-ranking-table td {
		padding: 14px 8px;
		border-bottom: 1px solid var(--ntr-border-light);
		vertical-align: middle;
	}

.ntr-main-rank-num {
	font-weight: bold;
	color: var(--ntr-primary);
	text-align: center;
}

	.ntr-main-rank-num.normal {
		color: var(--ntr-text-base);
	}

.ntr-main-rank-name {
	color:#000;
	font-weight: 500;
}

.ntr-main-rank-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: var(--ntr-radius-sm);
	font-size: var(--ntr-font-xs);
	font-weight: bold;
}

	.ntr-main-rank-badge.governance {
		background: var(--ntr-governance);
		color: #fff;
	}

	.ntr-main-rank-badge.premium {
		background: var(--ntr-premium);
		color: #fff;
	}

	.ntr-main-rank-badge.normal {
		background: var(--ntr-border-light);
		color: var(--ntr-text-secondary);
	}

.ntr-main-rank-points {
	text-align: right;
}

.ntr-main-rank-prize {
	text-align: right;
	color: var(--ntr-primary);
	font-weight: bold;
}

.ntr-main-rank-change {
	text-align: center;
	width: 50px;
}

.ntr-main-rank-up {
	color: var(--ntr-primary);
}

.ntr-main-rank-down {
	color: #1976d2;
}

.ntr-main-ranking-divider {
	text-align: center;
	padding: 10px;
	color: #ccc;
	font-size: var(--ntr-font-lg);
	letter-spacing: 4px;
}

.ntr-main-my-rank {
	background: #f8f8f8;
	border-left: 7px solid #b71c1c;
}

/* ===== TABS SECTION ===== */
.ntr-main-tabs-col {
	min-width: 0;
	overflow: hidden;
}

.ntr-main-tabs-section {
	background: var(--ntr-bg-light);
	padding: var(--ntr-spacing-3xl);
}

.ntr-main-tabs-wrap {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 40px;
}

.ntr-main-tabs-col-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: var(--ntr-spacing-lg);
}

.ntr-main-tabs-col-title {
	font-size: var(--ntr-font-lg);
	font-weight: bold;
	color: var(--ntr-text-dark);
}

.ntr-main-tabs-col-link {
	font-size: var(--ntr-font-base);
	color: var(--ntr-primary) !important;
	text-decoration: none;
}

	.ntr-main-tabs-col-link:hover {
		text-decoration: underline;
	}

	.ntr-main-tabs-col-link.gray {
		color: var(--ntr-text-muted);
	}

/* 회원 투표 */
.ntr-main-vote-box {
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-xl);
	height: 124px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.ntr-main-vote-box-item {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-light);
}

.ntr-main-vote-title {
	font-size: var(--ntr-font-md);
	font-weight: bold;
	margin-bottom: var(--ntr-spacing-sm);
	line-height: 1.6;
	color: var(--ntr-text-base);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ntr-main-vote-meta {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-muted);
	line-height: 1.6;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

/* 관심뉴스 */
.ntr-main-news-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--ntr-spacing-lg) var(--ntr-spacing-xl);
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: var(--ntr-radius-md);
	margin-bottom: var(--ntr-spacing-md);
	height: 56px;
	min-width: 0;
	overflow: hidden;
}

	.ntr-main-news-item a:last-child {
		margin-bottom: 0;
	}

.ntr-main-news-title {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-base);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	flex: 1;
	min-width: 0;
}

.ntr-main-news-time {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-light);
	flex-shrink: 0;
	margin-left: var(--ntr-spacing-sm);
}

/* 공지사항 */
.ntr-main-notice-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--ntr-spacing-lg) var(--ntr-spacing-xl);
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: var(--ntr-radius-md);
	margin-bottom: var(--ntr-spacing-md);
	height: 56px;
	min-width: 0;
	overflow: hidden;
}

	.ntr-main-notice-item a:last-child {
		margin-bottom: 0;
	}

.ntr-main-notice-content {
	display: flex;
	align-items: center;
	gap: var(--ntr-spacing-sm);
	flex: 1;
	min-width: 0;
	overflow: hidden;
}

.ntr-main-notice-badge {
	background: var(--ntr-primary);
	color: #fff;
	font-size: var(--ntr-font-xs);
	padding: 3px var(--ntr-spacing-xs);
	border-radius: 3px;
}

.ntr-main-notice-title {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-base);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	flex: 1;
	min-width: 0;
}
.ntr-main-notice-date {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-light);
	flex-shrink: 0;
	margin-left: var(--ntr-spacing-sm);
}

/* ===== MY MENU SECTION ===== */
.ntr-main-mymenu-section {
	background: #fff;
	padding: var(--ntr-spacing-3xl) 0;
}

.ntr-main-mymenu-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--ntr-spacing-lg);
}

.ntr-main-mymenu-btn {
	background: var(--ntr-bg-light);
	border: 1px solid var(--ntr-border);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-xl);
	text-align: center;
	cursor: pointer;
	transition: all 0.2s;
}

	.ntr-main-mymenu-btn:hover {
		background: #f0f0f0;
		border-color: #ccc;
	}

.ntr-main-mymenu-label {
	font-size: var(--ntr-font-lg);
	color: var(--ntr-text-base);
}

/* ===== BOTTOM TTR SECTION ===== */
.ntr-main-bottom {
	background: var(--ntr-primary);
	color: #fff;
	padding: var(--ntr-spacing-3xl);
}

.ntr-main-ttr-box {
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.3);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-xl) var(--ntr-spacing-2xl);
	margin-bottom: var(--ntr-spacing-xl);
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.ntr-main-ttr-label {
	font-size: var(--ntr-font-base);
	color: rgba(255,255,255,0.8);
	margin-bottom: var(--ntr-spacing-sm);
}

.ntr-main-ttr-value {
	font-size: var(--ntr-font-4xl);
	font-weight: bold;
	letter-spacing: -1px;
	color:#fff;
}

.ntr-main-ttr-desc {
	font-size: var(--ntr-font-xs);
	color: rgba(255,255,255,0.7);
	margin-top: var(--ntr-spacing-sm);
}

.ntr-main-ttr-total {
	text-align: right;
}

.ntr-main-ttr-total-label {
	font-size: var(--ntr-font-base);
	color: rgba(255,255,255,0.8);
}

.ntr-main-ttr-total-value {
	font-size: var(--ntr-font-xl);
	font-weight: bold;
	color: #fff;
	margin-left: var(--ntr-spacing-sm);
}

.ntr-main-ttr-link {
	display: inline-block;
	font-size: var(--ntr-font-xs) !important;
	color: rgba(255,255,255,0.7) !important;
	text-decoration: underline;
	margin-top: 10px;
}

	.ntr-main-ttr-link:hover {
		color: #fff;
	}

.ntr-main-bottom-btns {
	display: flex;
	gap: var(--ntr-spacing-lg);
}

.ntr-main-wallet-btn {
	flex: 1;
	background: rgba(255,255,255,0.1);
	border: 1px solid rgba(255,255,255,0.3);
	color: #fff !important;
	padding: var(--ntr-spacing-lg);
	border-radius: var(--ntr-radius-md);
	font-size: var(--ntr-font-md);
	font-weight: bold;
	cursor: pointer;
	transition: background 0.2s;
	text-align:center;
}

	.ntr-main-wallet-btn:hover {
		background: rgba(255,255,255,0.2);
	}

.ntr-main-claim-btn {
	flex: 2;
	background: #fff;
	border: none;
	color: var(--ntr-primary) !important;
	padding: var(--ntr-spacing-lg);
	border-radius: var(--ntr-radius-md);
	font-size: var(--ntr-font-md);
	font-weight: bold;
	cursor: pointer;
	transition: background 0.2s;
	text-align:center;
}

	.ntr-main-claim-btn:hover {
		background: #f5f5f5;
	}

/* ===== MODAL STYLES ===== */
.ntr-main-modal-overlay {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0,0,0,0.5);
	z-index: 1000;
	justify-content: center;
	align-items: flex-start;
	padding: 40px 20px;
	overflow-y: auto;
}

	.ntr-main-modal-overlay.active {
		display: flex;
	}

.ntr-main-modal {
	background: #fff;
	border-radius: var(--ntr-radius-lg);
	width: 100%;
	max-width: 500px;
	max-height: calc(100vh - 80px);
	overflow-y: auto;
	position: relative;
	box-shadow: 0 10px 40px rgba(0,0,0,0.2);
}

.ntr-main-modal-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--ntr-spacing-xl) var(--ntr-spacing-2xl);
	border-bottom: 1px solid var(--ntr-border);
	position: sticky;
	top: 0;
	background: #fff;
	z-index: 10;
}

.ntr-main-modal-title {
	font-size: var(--ntr-font-xl);
	font-weight: bold;
	color: var(--ntr-text-dark);
}

.ntr-main-modal-close {
	background: none;
	border: none;
	font-size: var(--ntr-font-2xl);
	color: var(--ntr-text-light);
	cursor: pointer;
	padding: 0;
	line-height: 1;
}

	.ntr-main-modal-close:hover {
		color: var(--ntr-text-base);
	}

.ntr-main-modal-body {
	padding: var(--ntr-spacing-2xl);
}

.ntr-main-modal-section {
	margin-bottom: var(--ntr-spacing-3xl);
}

	.ntr-main-modal-section:last-child {
		margin-bottom: 0;
	}

.ntr-main-modal-section-title {
	font-size: var(--ntr-font-md);
	font-weight: bold;
	color: var(--ntr-text-dark);
	margin-bottom: var(--ntr-spacing-md);
	padding-bottom: var(--ntr-spacing-sm);
	border-bottom: 1px solid var(--ntr-border);
}

.ntr-main-modal-text {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-secondary);
	line-height: 1.7;
	margin-bottom: var(--ntr-spacing-md);
}

	.ntr-main-modal-text:last-child {
		margin-bottom: 0;
	}

.ntr-main-modal-list {
	list-style: none;
	margin: var(--ntr-spacing-md) 0;
	padding-left: var(--ntr-spacing-sm);
}

	.ntr-main-modal-list li {
		font-size: var(--ntr-font-base);
		color: var(--ntr-text-secondary);
		padding: var(--ntr-spacing-xs) 0;
		padding-left: var(--ntr-spacing-lg);
		position: relative;
	}

		.ntr-main-modal-list li::before {
			content: "•";
			position: absolute;
			left: 0;
			color: var(--ntr-text-muted);
		}

.ntr-main-modal-formula {
	background: var(--ntr-bg-light);
	border-radius: var(--ntr-radius-md);
	padding: var(--ntr-spacing-lg);
	text-align: center;
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-base);
	margin: var(--ntr-spacing-lg) 0;
	font-weight: 500;
}

.ntr-main-modal-grade-list {
	list-style: none;
	margin: var(--ntr-spacing-md) 0;
	padding-left: var(--ntr-spacing-sm);
}

	.ntr-main-modal-grade-list li {
		font-size: var(--ntr-font-base);
		color: var(--ntr-text-secondary);
		padding: 6px 0;
		padding-left: var(--ntr-spacing-lg);
		position: relative;
	}

		.ntr-main-modal-grade-list li::before {
			content: "•";
			position: absolute;
			left: 0;
			color: var(--ntr-text-muted);
		}

.ntr-main-modal-table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--ntr-font-base);
	margin-top: var(--ntr-spacing-md);
}

	.ntr-main-modal-table th {
		background: var(--ntr-bg-light);
		padding: 10px var(--ntr-spacing-md);
		text-align: left;
		font-weight: normal;
		color: var(--ntr-text-secondary);
		border-bottom: 1px solid var(--ntr-border);
	}

	.ntr-main-modal-table td {
		padding: var(--ntr-spacing-md);
		border-bottom: 1px solid var(--ntr-border-light);
		color: var(--ntr-text-base);
	}

		.ntr-main-modal-table td:nth-child(2) {
			text-align: center;
			font-weight: bold;
			color: var(--ntr-primary);
		}

		.ntr-main-modal-table td:nth-child(3) {
			text-align: right;
			color: var(--ntr-text-muted);
			font-size: var(--ntr-font-xs);
		}

		.ntr-main-modal-table td.minus {
			color: #1976d2;
		}

.ntr-main-modal-sub-section {
	margin-top: var(--ntr-spacing-lg);
}

.ntr-main-modal-sub-title {
	font-size: var(--ntr-font-base);
	font-weight: bold;
	color: var(--ntr-text-base);
	margin-bottom: var(--ntr-spacing-sm);
}

.ntr-main-modal-sub-list {
	list-style: none;
	padding-left: var(--ntr-spacing-sm);
}

	.ntr-main-modal-sub-list li {
		font-size: var(--ntr-font-xs);
		color: var(--ntr-text-secondary);
		padding: var(--ntr-spacing-xs) 0;
		padding-left: var(--ntr-spacing-lg);
		position: relative;
	}

		.ntr-main-modal-sub-list li::before {
			content: "•";
			position: absolute;
			left: 0;
			color: var(--ntr-text-light);
		}

.ntr-main-modal-note {
	font-size: var(--ntr-font-xs);
	color: var(--ntr-text-muted);
	margin-bottom: var(--ntr-spacing-md);
}

/* 등급 체계 모달 */
.ntr-main-grade-table {
	width: 100%;
	border-collapse: collapse;
}

	.ntr-main-grade-table thead th {
		background: var(--ntr-bg-light);
		padding: var(--ntr-spacing-md) var(--ntr-spacing-lg);
		text-align: left;
		font-size: var(--ntr-font-base);
		font-weight: normal;
		color: var(--ntr-text-secondary);
		border-bottom: 1px solid var(--ntr-border);
	}

	.ntr-main-grade-table tbody td {
		padding: var(--ntr-spacing-xl) var(--ntr-spacing-lg);
		border-bottom: 1px solid var(--ntr-border-light);
		vertical-align: top;
	}

	.ntr-main-grade-table tbody tr:last-child td {
		border-bottom: none;
	}

.ntr-main-grade-badge-btn {
	display: inline-block;
	padding: var(--ntr-spacing-sm) var(--ntr-spacing-xl);
	border-radius: 6px;
	font-size: var(--ntr-font-base);
	font-weight: bold;
	text-align: center;
	min-width: 100px;
}

	.ntr-main-grade-badge-btn.governance {
		background: var(--ntr-governance);
		color: #fff;
	}

	.ntr-main-grade-badge-btn.premium {
		background: var(--ntr-premium);
		color: #fff;
	}

	.ntr-main-grade-badge-btn.normal {
		background: var(--ntr-border-light);
		color: var(--ntr-text-secondary);
		border: 1px solid var(--ntr-border);
	}

.ntr-main-grade-condition {
	margin-bottom: var(--ntr-spacing-md);
}

	.ntr-main-grade-condition strong {
		font-size: var(--ntr-font-base);
		color: var(--ntr-text-base);
		display: block;
		margin-bottom: var(--ntr-spacing-xs);
	}

	.ntr-main-grade-condition p {
		font-size: var(--ntr-font-base);
		color: var(--ntr-text-secondary);
		margin: 0;
	}

.ntr-main-grade-benefit-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

	.ntr-main-grade-benefit-list li {
		font-size: var(--ntr-font-xs);
		color: var(--ntr-text-secondary);
		padding: var(--ntr-spacing-xs) 0;
		padding-left: var(--ntr-spacing-lg);
		position: relative;
	}

		.ntr-main-grade-benefit-list li::before {
			content: "•";
			position: absolute;
			left: 0;
			color: var(--ntr-text-light);
		}

/* 청구 내역 모달 */
.ntr-main-history-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 14px 0;
	border-bottom: 1px solid var(--ntr-border-light);
}

	.ntr-main-history-item:last-child {
		border-bottom: none;
	}

.ntr-main-history-date {
	font-size: var(--ntr-font-base);
	color: var(--ntr-text-secondary);
}

.ntr-main-history-amount {
	font-size: var(--ntr-font-base);
	font-weight: bold;
	color: var(--ntr-text-base);
}

.ntr-main-history-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 0;
	border-bottom: 1px solid #eee;
}

.ntr-main-history-status {
	font-size: 12px;
	padding: 4px 8px;
	border-radius: 4px;
}

	.ntr-main-history-status.pending {
		background: #fff3cd;
		color: #856404;
	}

	.ntr-main-history-status.complete {
		background: #d4edda;
		color: #155724;
	}

.ntr-main-history-empty {
	text-align: center;
	padding: 40px 0;
	color: #999;
}

/* ===== CONTAINER ===== */
.ntr-board-container {
	width: 890px;
	margin: 0 0 20px;
	padding: 0;
	position: relative;
	float: left;
}

/* ===== HEADER ===== */
.ntr-board-header {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 0 0 20px 0;
	border-bottom: 1px solid var(--ntr-border);
}

.ntr-board-logo {
	font-size: 28px;
	font-weight: bold;
	color: var(--ntr-primary);
	cursor:pointer;
}

.ntr-board-subtitle {
	font-size: 14px;
	color: var(--ntr-text-muted);
	margin-top: 4px;
}

.ntr-board-write-btn {
	background: var(--ntr-primary);
	color: #fff;
	border: none;
	padding: 12px 32px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: bold;
	cursor: pointer;
	transition: background 0.2s;
}

	.ntr-board-write-btn:hover {
		background: var(--ntr-primary-dark);
	}

/* ===== 실시간 주요 게시글 섹션 ===== */
.ntr-board-realtime {
	background: #fdf6f6;
	padding: 24px 28px;
	border-left: 4px solid var(--ntr-primary);
	margin-top: 0;
}

.ntr-board-realtime-title {
	font-size: 15px;
	font-weight: bold;
	color: var(--ntr-primary);
	margin-bottom: 16px;
	display: flex;
	align-items: center;
	gap: 8px;
}

	.ntr-board-realtime-title::before {
		content: "▶";
		font-size: 11px;
	}

.ntr-board-realtime-list {
	list-style: none;
}

.ntr-board-realtime-item {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 12px 0;
	border-bottom: 1px solid #f0e0e0;
}

	.ntr-board-realtime-item:last-child {
		border-bottom: none;
		padding-bottom: 0;
	}

	.ntr-board-realtime-item:first-child {
		padding-top: 0;
	}

.ntr-board-realtime-item-title {
	font-size: 16px;
	color: var(--ntr-text-base);
}

.ntr-board-realtime-item-meta {
	display: flex;
	gap: 16px;
	font-size: 14px;
	color: var(--ntr-text-muted);
}

/* ===== 탭 + 검색 영역 ===== */
.ntr-board-toolbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px 0;
	border-bottom: 1px solid var(--ntr-border);
}

.ntr-board-tabs {
	display: flex;
	gap: 0;
}

.ntr-board-tab {
	padding: 10px 24px;
	font-size: 14px;
	color: var(--ntr-text-secondary);
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-right: none;
	cursor: pointer;
	transition: all 0.2s;
}

	.ntr-board-tab:first-child {
		border-radius: 6px 0 0 6px;
	}

	.ntr-board-tab:last-child {
		border-radius: 0 6px 6px 0;
		border-right: 1px solid var(--ntr-border);
	}

	.ntr-board-tab.active {
		background: var(--ntr-primary);
		color: #fff;
		border-color: var(--ntr-primary);
	}

	.ntr-board-tab:hover:not(.active) {
		background: var(--ntr-bg-light);
	}

.ntr-board-search {
	display: flex;
	gap: 0;
}

.ntr-board-search-input {
	width: 200px;
	padding: 10px 16px;
	color:#000;
	font-size: 14px !important;
	border: 1px solid var(--ntr-border);
	border-radius: 6px 0 0 6px;
	outline: none;
}

	.ntr-board-search-input:focus {
		border-color: var(--ntr-primary);
	}

	.ntr-board-search-input::placeholder {
		color: var(--ntr-text-light);
	}

.ntr-board-search-btn {
	padding: 10px 20px;
	background: var(--ntr-primary);
	color: #fff;
	border: 1px solid var(--ntr-primary);
	border-radius: 0 6px 6px 0;
	font-size: 14px;
	cursor: pointer;
	transition: background 0.2s;
}

	.ntr-board-search-btn:hover {
		background: var(--ntr-primary-dark);
	}

/* ===== 게시글 테이블 ===== */
.ntr-board-table {
	width: 100%;
	border-collapse: collapse;
}

	.ntr-board-table thead {
		background: var(--ntr-bg-light);
		border-top: 2px solid var(--ntr-text-base);
	}

	.ntr-board-table th {
		padding: 14px 12px;
		font-size: 14px;
		font-weight: normal;
		color: var(--ntr-text-secondary);
		text-align: center;
		border-bottom: 1px solid var(--ntr-border);
	}

		.ntr-board-table th.title {
			text-align: center;
		}

	.ntr-board-table td {
		padding: 18px 12px;
		font-size: 14px;
		border-bottom: 1px solid var(--ntr-border-light);
		text-align: center;
		vertical-align: middle;
	}

		.ntr-board-table td.title {
			text-align: left;
			font-size: 16px;
			color: var(--ntr-text-base);
			max-width: 480px; /* 적절한 너비 설정 */
			white-space: nowrap;
			overflow: hidden;
			text-overflow: ellipsis;
		}

			.ntr-board-table td.title a {
				color: var(--ntr-text-base);
				text-decoration: none;
				display: block;
				white-space: nowrap;
				overflow: hidden;
				text-overflow: ellipsis;
			}

				.ntr-board-table td.title a:hover {
					color: var(--ntr-primary);
				}

		.ntr-board-table td.author {
			white-space: nowrap;
		}

.ntr-board-author-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.ntr-board-author-name {
	color: var(--ntr-text-base);
	font-size:14px;
}

.ntr-board-badge {
	display: inline-block;
	padding: 3px 8px;
	border-radius: 4px;
	font-size: 11px;
	font-weight: bold;
}

	.ntr-board-badge.governance {
		background: var(--ntr-governance);
		color: #fff;
	}

	.ntr-board-badge.premium {
		background: var(--ntr-premium);
		color: #fff;
	}

.ntr-board-table td.views,
.ntr-board-table td.comments {
	color: var(--ntr-text-secondary);
}

.ntr-board-table td.date {
	color: var(--ntr-text-muted);
	font-size: 14px;
}

/* ===== 페이지네이션 ===== */
.ntr-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 24px 0;
}

.ntr-pagination {
	display: flex;
	align-items: center;
	gap: 4px;
	margin: 0 auto;
}

.ntr-page-btn {
	display: flex;
	align-items: center;
	gap: 4px;
	padding: 8px 14px;
	font-size: 14px;
	color: var(--ntr-text-secondary);
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.2s;
}

	.ntr-page-btn:hover {
		background: var(--ntr-bg-light);
	}

.ntr-page-num {
	min-width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	color: var(--ntr-text-secondary);
	background: #fff;
	border: 1px solid var(--ntr-border);
	border-radius: 4px;
	cursor: pointer;
	transition: all 0.2s;
}

	.ntr-page-num:hover {
		background: var(--ntr-bg-light);
	}

	.ntr-page-num.active {
		background: var(--ntr-primary);
		color: #fff;
		border-color: var(--ntr-primary);
	}

.ntr-page-dots {
	padding: 0 8px;
	color: var(--ntr-text-muted);
}

.ntr-footer-write {
	background: var(--ntr-primary);
	color: #fff;
	border: none;
	padding: 12px 32px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: bold;
	cursor: pointer;
	transition: background 0.2s;
}

	.ntr-footer-write:hover {
		background: var(--ntr-primary-dark);
	}

/* 테이블 컬럼 너비 */
.ntr-board-table .col-title {
	width: auto;
}

.ntr-board-table .col-author {
	width: 140px;
}

.ntr-board-table .col-views {
	width: 80px;
}

.ntr-board-table .col-comments {
	width: 80px;
}

.ntr-board-table .col-date {
	width: 100px;
}