@charset "UTF-8";

:root {
	/* ── 브랜드 컬러 팔레트 ── */
	--espresso: #2C1810; /* 가장 어두운 브라운 (메인 텍스트, 제목) */
	--dark-roast: #3D2314; /* 다크 브라운 (강조 텍스트, 답변 본문) */
	--coffee: #5D4037; /* 미디엄 브라운 (그라디언트 끝값) */
	--mocha: #6F4E37; /* 라이트 브라운 (보조 텍스트, 링크) */
	--caramel: #C9A962; /* 골드 포인트 (버튼, 라인, 뱃지) */
	--latte: #E8D5B7; /* 연한 베이지 (답변 헤더 하단선) */
	--cream: #F5E6D3; /* 크림 (테이블 헤더 텍스트, 버튼 텍스트) */
	--warm-cream: #FDF8F3; /* 가장 밝은 크림 (body 배경, 호버 배경) */
	/* ── 보더 ── */
	--border: rgba(201, 169, 98, 0.15);
	--border-hover: rgba(201, 169, 98, 0.40);
}

.container {
	max-width: 1200px;
	margin: 50px auto 0;
	padding-bottom: 120px;
	width: 90%;
	font-size: 1.6rem;
}

.page-content {
	min-height: calc(100vh - 200px);
}

.btn {
	display: inline-block;
	padding: 12px 28px;
	border-radius: 8px;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	transition: .3s;
	border: none;
	text-align: center;
}

/* Buttons - 카라멜/에스프레소 톤 */
.btn {
	display: inline-block;
	padding: 12px 28px;
	border-radius: 6px;
	font-size: 14px;
	font-weight: 500;
	cursor: pointer;
	transition: .3s;
	border: none;
	text-align: center
}

.btn-primary {
	background: linear-gradient(135deg, #C9A962, #B8954A);
	color: #fff;
	box-shadow: 0 4px 12px rgba(201, 169, 98, .3)
}

.btn-primary:hover {
	background: linear-gradient(135deg, #B8954A, #A68238);
	box-shadow: 0 6px 16px rgba(201, 169, 98, .4)
}

.btn-secondary {
	background: #5D4037;
	color: #F5E6D3 !important
}

.btn-secondary:hover {
	background: #4A3728
}

.btn-outline {
	border: 1px solid #C9A962;
	color: #6F4E37;
	background: transparent
}

.btn-outline:hover {
	background: #C9A962;
	color: #fff
}

.btn-danger {
	background: #8B4513;
	color: #fff
}

.btn-danger:hover {
	background: #6F4E37
}

.btn-sm {
	padding: 8px 16px;
	font-size: 13px
}

.btn-lg {
	padding: 16px 40px;
	font-size: 16px;
	border-radius: 8px
}

.btn-lg {
	padding: 16px 40px;
	font-size: 16px;
	border-radius: 8px;
}

.btn-block {
	display: block;
	width: 100%
}

/* 선택하기 버튼 (카드 내부) */
.room-card .select-btn, .room-card button {
	width: 100%;
	margin-top: 12px;
	padding: 10px 0;
	border: 1.5px solid #C9A962;
	border-radius: 4px;
	background: transparent;
	color: #8a6b2e;
	font-size: 1.6rem;
	cursor: pointer;
	transition: background 0.25s, color 0.25s;
	color: #000 !important;
}

.room-card .select-btn:hover, .room-card button:hover, .room-card.selected .select-btn,
	.room-card.selected button {
	background: #C9A962;
	color: #fff;
}

.section {
	padding: 70px 0;
	background: var(--warm-cream);
}

.section-title {
	text-align: center;
	margin-bottom: 48px;
}

.section-title h2 {
	font-size: 34px;
	font-weight: 600;
	color: var(--espresso);
	margin-bottom: 12px;
	letter-spacing: 2px;
}

.section-title h2::after {
	content: '';
	display: block;
	width: 60px;
	height: 3px;
	background: linear-gradient(90deg, var(--caramel), var(--coffee));
	margin: 14px auto 0;
	border-radius: 2px;
}

.section-title p {
	color: var(--mocha);
	font-size: 16px;
	font-weight: 400;
}

.form-group {
	margin-bottom: 20px;
}

.form-group label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	margin-bottom: 6px;
	color: var(--dark-roast);
}

.form-control {
	width: 100%;
	padding: 10px 14px;
	border: 1px solid var(--latte);
	border-radius: 4px;
	font-size: 14px;
	transition: .3s;
}

.form-control:focus {
	outline: none;
	border-color: var(--caramel);
	box-shadow: 0 0 0 3px var(--border);
}

textarea.form-control {
	min-height: 120px;
	resize: vertical;
}

.input-group {
	display: flex;
	gap: 8px;
}

.input-group .form-control {
	flex: 1;
}

.form-check {
	display: flex;
	align-items: center;
	gap: 8px;
}

.form-check input[type="checkbox"] {
	width: 18px;
	height: 18px;
}

.error-text {
	color: #dc3545;
	font-size: 13px;
	margin-top: 4px;
}

.success-text {
	color: #28a745;
	font-size: 13px;
	margin-top: 4px;
}

.form-box {
	margin: 0 auto;
	background: var(--warm-cream);
	padding: 40px;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}

.form-box h2 {
	text-align: center;
	margin-bottom: 30px;
	font-size: 24px;
	color: var(--espresso);
}

.form-box h2::after {
	content: '';
	display: block;
	width: 40px;
	height: 3px;
	background: var(--caramel);
	margin: 10px auto 0;
}

.table-wrap {
	overflow-x: auto;
	border-radius: 8px 8px 0 0;
	margin-bottom: 10px;
}

table {
	width: 100%;
	border-collapse: collapse;
	background: #fff;
}

table th, table td {
	padding: 12px 15px;
	text-align: center;
	border-bottom: 1px solid var(--latte);
	font-size: 14px;
}

table th {
	background: var(--coffee);
	color: var(--cream);
	font-weight: 500;
}

table tbody tr:hover {
	background: var(--warm-cream);
}

table .text-left {
	text-align: left;
}

.qna-table th:nth-child(1) {
	width: 80px;
}

.qna-table th:nth-child(3) {
	width: 100px;
}

.qna-table th:nth-child(4) {
	width: 100px;
}

.qna-table th:nth-child(5) {
	width: 120px;
}

.qna-empty {
	padding: 40px;
}

.paging-info {
	margin-top: 20px;
	text-align: right;
	padding: 10px;
	font-size: 14px;
	color: var(--mocha);
}

.paging-info strong {
	color: var(--espresso);
}

.pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 5px;
	margin-top: 16px;
	flex-wrap: wrap;
}

.pagination a, .pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border: 1px solid var(--latte);
	border-radius: 4px;
	font-size: 14px;
	transition: .3s;
}

.pagination a:hover {
	background: var(--caramel);
	color: var(--warm-cream);
	border-color: var(--caramel);
}

.pagination .active {
	background: var(--caramel);
	color: var(--warm-cream);
	border-color: var(--caramel);
	font-weight: 700;
}

.pagination .disabled {
	color: var(--latte);
	background: var(--warm-cream);
	border-color: var(--latte);
	cursor: default;
	pointer-events: none;
}

.board-header {
	display: flex;
	justify-content: end;
	align-items: center;
	margin-bottom: 20px;
	flex-wrap: wrap;
	gap: 10px;
}

.board-header h3 {
	font-size: 22px;
	color: var(--espresso);
}

.search-box {
	display: flex;
	gap: 8px;
}

.search-box input {
	width: 250px;
}

.board-view {
	background: #fff;
	border-radius: 8px;
	padding: 30px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}

.board-view .view-title {
	font-size: 22px;
	font-weight: 600;
	margin-bottom: 10px;
	color: var(--espresso);
}

.board-view .view-info {
	color: var(--mocha);
	font-size: 1.6rem;
	margin-bottom: 20px;
	padding-bottom: 15px;
	border-bottom: 1px solid var(--latte);
	display: flex;
	gap: 20px;
	justify-content: space-between;
}

.board-view .view-content {
	min-height: 200px;
	line-height: 1.8;
	white-space: pre-wrap;
	border: 1px solid var(--latte);
	padding: 25px;
	border-radius: 20px;
	background-color: var(--warm-cream);
}

.board-nav {
	margin-top: 20px;
	border-top: 1px solid var(--latte);
	padding-top: 15px;
}

.board-nav a {
	display: block;
	padding: 8px 0;
	color: var(--mocha);
	font-size: 14px;
}

.board-nav a:hover {
	color: var(--dark-roast);
}

.board-actions {
	display: flex;
	justify-content: center;
	gap: 10px;
	margin-top: 30px;
}

.qna-answer-section {
	margin-top: 25px;
	border: 2px solid var(--caramel);
	border-radius: 12px;
	overflow: hidden;
	background: #fff;
}

.qna-answer-header {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 14px 20px;
	background: linear-gradient(135deg, var(--warm-cream), var(--cream));
	border-bottom: 1px solid var(--latte);
	font-size: 14px;
}

.qna-answer-icon {
	font-size: 18px;
}

.qna-answer-date {
	margin-left: auto;
	color: var(--mocha);
	font-size: 12px;
}

.qna-answer-body {
	padding: 20px;
	line-height: 1.8;
	white-space: pre-wrap;
	font-size: 14px;
	color: var(--dark-roast);
}

.faq-item {
	border: 1px solid var(--border);
	border-radius: 8px;
	margin-bottom: 10px;
	box-sizing: border-box;
	overflow: hidden;
}

.faq-question {
	padding: 18px 20px;
	background: #fff;
	cursor: pointer;
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-weight: 500;
	transition: .3s;
}

.faq-question:hover {
	background: var(--warm-cream);
}

.faq-question.active {
	border-color: var(--border-hover);
	z-index: 1;
	position: relative;
	background-color: var(--bg3);
}

.faq-question .category-badge {
	background: var(--mocha);
	color: var(--cream);
	padding: 2px 10px;
	border-radius: 12px;
	font-size: 12px;
	margin-right: 12px;
}

.faq-question .arrow {
	transition: .3s;
	font-size: 12px;
}

.faq-question.active .arrow {
	transform: rotate(180deg);
}

.faq-answer {
	padding: 0 20px;
	max-height: 0;
	overflow: hidden;
	transition: .4s;
	background: var(--warm-cream);
	line-height: 1.8;
}

.faq-answer.show {
	padding: 18px 20px;
	max-height: 500px;
}

.faq-item:has(>.faq-question.active) {
	border-left: 3px solid var(--dark-roast);
}

.rsv-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}

.badge {
	display: inline-block;
	padding: 4px 8px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
}

.badge-waiting {
	background: rgba(201, 160, 108, 0.23);
	color: #8b6e3c;
	border: 1px solid rgba(201, 160, 108, 0.3);
}

.badge-answered {
	background: rgba(58, 28, 11, 0.23);
	color: #5a3521;
	border: 1px solid rgba(58, 28, 11, 0.15);
}

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.text-gold {
	color: var(--caramel);
}

.text-mocha {
	color: var(--mocha);
}

.mt-10 {
	margin-top: 10px;
}

.mt-20 {
	margin-top: 20px;
}

.mt-30 {
	margin-top: 30px;
}

.mb-10 {
	margin-bottom: 10px;
}

.mb-20 {
	margin-bottom: 20px;
}

.bg-white {
	background: #fff;
}

.bg-cream {
	background: var(--warm-cream);
}

.rounded {
	border-radius: 8px;
}

.shadow {
	box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}

.flex {
	display: flex;
}

.flex-between {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.gap-10 {
	gap: 10px;
}

.w-100 {
	width: 100%;
}

.no-data {
	text-align: center;
	padding: 60px 20px;
	color: var(--mocha);
}

.no-data p {
	font-size: 16px;
}

.tab-btns {
	display: flex;
	gap: 10px;
	margin-bottom: 20px;
}

.tab-btns a {
	padding: 8px 30px;
	border: 1px solid var(--line3);
	border-radius: 8px;
	font-size: 2.0rem;
	transition: .3s;
	color: var(--point2);
}

.tab-btns a:hover, .tab-btns a.active {
	background: var(--dark-roast);
	color: var(--cream);
	border-color: var(--dark-roast);
}

.rsv-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 30px;
}

@media ( max-width : 768px) {
	.header .container {
		flex-wrap: wrap;
		height: auto;
		padding: 15px 20px;
	}
	.gnb {
		gap: 15px;
		font-size: 13px;
	}
	.hero {
		height: 420px;
		min-height: 420px;
	}
	.hero-content h1 {
		font-size: 32px;
	}
	.hero-prev, .hero-next {
		display: none;
	}
	.card-grid {
		grid-template-columns: 1fr;
	}
	.mypage-wrap {
		grid-template-columns: 1fr;
	}
	.admin-wrap {
		grid-template-columns: 1fr;
	}
	.admin-sidebar {
		display: none;
	}
	.dash-grid {
		grid-template-columns: 1fr;
	}
	.rsv-grid {
		grid-template-columns: 1fr;
	}
}

@media ( min-width : 768px) and (max-width: 1024px) {
	.page-content .search-box .form-control {
		width: 180px;
	}
}

@media ( max-width : 767px) {
	.badge {
		font-size: 9px;
	}
	.page-content .board-header {
		flex-direction: column;
		align-items: flex-start;
	}
	.page-content .search-box {
		width: 100%;
	}
	.page-content .search-box .form-control {
		flex: 1;
		width: auto;
	}
	.page-content .qna-table th:nth-child(1), .page-content .qna-table td:nth-child(1),
		.page-content .qna-table th:nth-child(3), .page-content .qna-table td:nth-child(3),
		.page-content .qna-table th:nth-child(5), .page-content .qna-table td:nth-child(5)
		{
		display: none;
	}
	.page-content .qna-table th:nth-child(4), .page-content .qna-table td:nth-child(4)
		{
		width: 88px;
	}
}

@media ( max-width : 480px) {
	/* 문의작성 버튼 전체 너비 */
	.page-content .text-right.mb-10 .btn {
		display: block;
		width: 100%;
		text-align: center;
	}
}