/* ══════════════════════════════════════════════
   단체체험 전체 CSS (독립 사용 가능)
   ══════════════════════════════════════════════ */

/* ── 탭 네비게이션 ── */
.dg-tab-nav {
	display: flex;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid #e0e0e0;
	margin-bottom: 1.5rem;
}
.dg-tab-nav__item {
	flex: 1;
	text-align: center;
	padding: .7rem 1rem;
	font-size: .95rem;
	font-weight: 700;
	color: #555;
	background: #fff;
	text-decoration: none;
	border-right: 1px solid #e0e0e0;
	transition: background .15s, color .15s;
}
.dg-tab-nav__item:last-child { border-right: none; }
.dg-tab-nav__item.is-active {
	background: linear-gradient(135deg, #8ca078, #3d5a2e);
	color: #fff;
	font-weight: 800;
}
.dg-tab-nav__item:hover {
	background: rgba(61,90,46,.1);
	color: #2d4a1e;
	text-decoration: none;
}
.dg-tab-nav__item.is-active:hover {
	background: linear-gradient(135deg, #8ca078, #3d5a2e);
	color: #fff;
}

@media (max-width: 768px) {
	.dg-tab-nav__item { padding: .55rem .5rem; font-size: .85rem; }
}

/* =============================================
   0. ROOT
============================================= */
.dg-board-page {
	font-family: 'Pretendard', 'Noto Sans KR', sans-serif;
	letter-spacing: -0.02em;
	color: var(--dg-text, #1e293b);
	min-width: 0;
	max-width: 100%;
}

/* =============================================
   1. CARD (info-card)
============================================= */
.dg-info-card {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0,0,0,.06);
	overflow: hidden;
	min-width: 0;
	margin-bottom: 1.5rem;
}
.dg-info-card__head {
	display: flex;
	align-items: center;
	gap: .85rem;
	padding: .5rem 1.25rem;
	background: var(--dg-primary-gradient);
	border-radius: 16px 16px 0 0;
}
.dg-info-card__icon {
	width: 38px; height: 38px;
	border-radius: 10px;
	background: rgba(45,74,30,.10);
	display: flex; align-items: center; justify-content: center;
	color: #2d4a1e; font-size: 1.05rem; flex-shrink: 0;
}
.dg-info-card__label {
	display: inline-block;
	font-size: .62rem; font-weight: 600;
	color: #2d4a1e;
	background: rgba(45,74,30,.12);
	padding: .12rem .5rem;
	border-radius: 4px;
	margin-bottom: .15rem;
}
.dg-info-card__title {
	font-family: 'Noto Serif KR', serif;
	font-size: 1.05rem; font-weight: 700;
	color: #2d4a1e; margin: 0;
}
.dg-info-card__badge {
	margin-left: auto;
	font-size: .75rem;
	color: rgba(45,74,30,.6);
	white-space: nowrap;
}
.dg-info-card__body {
	padding: 1.25rem 1.5rem;
	min-width: 0;
	overflow: hidden;
}

/* =============================================
   1-1. ACADEMY CARD (관리자 리스트용)
============================================= */
.dg-academy-card {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 2px 12px rgba(0,0,0,.06);
	overflow: hidden;
	min-width: 0;
	margin-bottom: 1.5rem;
}
.dg-academy-card__head {
	display: flex;
	align-items: center;
	gap: .85rem;
	padding: .5rem 1.25rem;
	background: var(--dg-primary-gradient);
	border-radius: 16px 16px 0 0;
}
.dg-academy-card__icon {
	width: 38px; height: 38px;
	border-radius: 10px;
	background: rgba(45,74,30,.10);
	backdrop-filter: blur(4px);
	display: flex; align-items: center; justify-content: center;
	color: #2d4a1e; font-size: 1.05rem; flex-shrink: 0;
}
.dg-academy-card__label {
	display: inline-block;
	font-size: .62rem; font-weight: 600;
	color: #2d4a1e;
	background: rgba(45,74,30,.12);
	padding: .12rem .5rem;
	border-radius: 4px;
	margin-bottom: .15rem;
	letter-spacing: .02em;
}
.dg-academy-card__title {
	font-family: 'Noto Serif KR', serif;
	font-size: 1.05rem; font-weight: 700;
	color: #2d4a1e; margin: 0;
}
.dg-academy-card__badge {
	margin-left: auto;
	font-size: .75rem;
	color: rgba(45,74,30,.6);
	white-space: nowrap;
}
.dg-academy-card__body {
	padding: 1.25rem 1.5rem;
	min-width: 0;
	overflow: hidden;
}

/* =============================================
   2. TOOLBAR / SEARCH
============================================= */
.dg-board-toolbar {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-wrap: wrap;
	margin-bottom: 20px;
	padding-bottom: 18px;
	border-bottom: 1px solid rgba(2,6,23,.06);
}
.dg-admin-btns {
	display: flex;
	gap: 4px;
}
.dg-board-search {
	display: flex;
	align-items: center;
	gap: 6px;
	margin-left: auto;
	flex-wrap: nowrap;
}
.dg-board-search .form-select,
.dg-board-search .form-control {
	font-size: .85rem;
	border-color: rgba(2,6,23,.12);
	border-radius: 8px;
	padding: 6px 12px;
}
.dg-board-search .form-control { width: 140px; flex-shrink: 1; min-width: 80px; }
.dg-board-search .form-select:focus,
.dg-board-search .form-control:focus {
	border-color: #8ca078;
	box-shadow: 0 0 0 3px rgba(140,176,120,.15);
}
.dg-board-search .btn {
	border-color: rgba(2,6,23,.12);
	color: var(--dg-text-sub, #64748b);
	border-radius: 8px;
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
}
.dg-board-search .btn:hover {
	background: rgba(140,176,120,.08);
	color: #2d4a1e;
}

/* ── 글쓰기/관리 버튼 ── */
.dg-btn-write {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 7px 16px;
	background: #3d5a2e;
	color: #fff;
	border: none; border-radius: 8px;
	font-size: .85rem; font-weight: 600;
	text-decoration: none;
	transition: background .2s;
	white-space: nowrap;
}
.dg-btn-write:hover {
	background: #2d4a1e;
	color: #fff;
	text-decoration: none;
}

/* ── 검색 결과 정보 ── */
.dg-board-info {
	font-size: .84rem;
	color: var(--dg-text-sub, #64748b);
}
.dg-board-info strong {
	color: var(--dg-text, #1e293b);
	font-weight: 700;
}

/* =============================================
   3. FILTER BAR
============================================= */
.dg-filter-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 20px;
}
.dg-filter-bar .filter-label {
	font-size: .82rem; font-weight: 600;
	color: var(--dg-text-sub, #64748b);
	margin-right: 4px;
}

/* =============================================
   4. TABLE
============================================= */
.fee-wrap-inner {
	width: 0;
	min-width: 100%;
	overflow: hidden;
}
.fee-scroll {
	width: 0;
	min-width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.fee-scroll::-webkit-scrollbar { height: 4px; }
.fee-scroll::-webkit-scrollbar-thumb { background: #ccc; border-radius: 2px; }

/* ── 공통 테이블 ── */
.dg-table,
.dg-mgmt-table,
.dg-result-table {
	width: 100%;
	border-collapse: collapse;
	font-size: .88rem;
}
.dg-table th,
.dg-mgmt-table th,
.dg-result-table th {
	background: rgba(140,176,120,.18);
	color: #2d4a1e;
	font-weight: 700; font-size: .82rem;
	padding: 12px 14px;
	text-align: center;
	border: 1px solid rgba(0,0,0,.06);
	white-space: nowrap;
}
.dg-table td,
.dg-mgmt-table td,
.dg-result-table td {
	padding: 12px 14px;
	border: 1px solid rgba(0,0,0,.06);
	vertical-align: middle;
	color: var(--dg-text, #1e293b);
	background: #fff;
}
.dg-table tbody tr:hover td,
.dg-mgmt-table tbody tr:hover td { background: rgba(140,176,120,.04); }
.dg-table .td-center,
.dg-mgmt-table .td-center,
.dg-result-table .td-center { text-align: center; }
.dg-table a,
.dg-mgmt-table a { color: var(--dg-text, #1e293b); text-decoration: none; font-weight: 500; }
.dg-table a:hover,
.dg-mgmt-table a:hover { color: #3d5a2e; }
.dg-table .badge-new,
.dg-mgmt-table .badge-new {
	display: inline-block; font-size: .65rem; font-weight: 700;
	color: #fff; background: #ef4444;
	padding: 1px 5px; border-radius: 4px; margin-left: 4px;
}

/* 결과 테이블 변형 */
.dg-result-table th {
	background: #f8fafc; color: var(--dg-text-sub, #64748b); font-weight: 600;
	width: 100px;
}
.dg-result-table th,
.dg-result-table td { padding: 12px 18px; }

/* status-form in table */
.dg-table .status-form,
.dg-mgmt-table .status-form {
	display: flex; align-items: center; gap: 4px; justify-content: center;
}
.dg-table .status-form .form-select,
.dg-mgmt-table .status-form .form-select {
	font-size: .82rem; padding: 4px 8px; border-radius: 6px;
	border-color: rgba(2,6,23,.12); width: auto; min-width: 80px;
}
.dg-table .status-form .form-select:focus,
.dg-mgmt-table .status-form .form-select:focus {
	border-color: #8ca078; box-shadow: 0 0 0 2px rgba(140,176,120,.15);
}

/* =============================================
   5. PAGINATION
============================================= */
.dg-pagination-row {
	display: flex; align-items: center; justify-content: center;
	gap: 16px; margin: 24px 0 16px;
}
.dg-pagination-row .pagebox01 {
	display: flex; align-items: center; gap: 6px;
}
.dg-pagination-row .pagebox01 * { float: none !important; margin: 0 !important; }
.dg-pagination-row .pagebox01 img { display: none !important; }
.dg-pagination-row .pagebox01 a,
.dg-pagination-row .pagebox01 span,
.dg-pagination-row .pagebox01 strong,
.dg-pagination-row .pagebox01 font {
	display: inline-flex !important;
	align-items: center; justify-content: center;
	min-width: 36px; height: 36px; padding: 0 12px;
	font-size: .84rem; font-weight: 500;
	color: var(--dg-text-sub, #64748b);
	background: #fff; border: 1px solid rgba(2,6,23,.1);
	border-radius: 8px; text-decoration: none;
}
.dg-pagination-row .pagebox01 a:hover {
	background: rgba(140,176,120,.08); border-color: rgba(140,176,120,.25); color: #2d4a1e;
}
.dg-pagination-row .pagebox01 span,
.dg-pagination-row .pagebox01 strong,
.dg-pagination-row .pagebox01 font {
	background: #3d5a2e; border-color: #3d5a2e; color: #fff !important; font-weight: 700;
}
.dg-pagination-row > .btn {
	display: inline-flex; align-items: center; justify-content: center;
	height: 36px; padding: 0 16px;
	font-size: .84rem; font-weight: 500;
	border-radius: 8px; border-color: rgba(2,6,23,.12);
	color: var(--dg-text-sub, #64748b); white-space: nowrap;
}
.dg-pagination-row > .btn:hover { background: #f1f5f9; border-color: rgba(2,6,23,.2); }

/* =============================================
   6. INQUIRY FORM (조회)
============================================= */
.dg-inquiry-form { max-width: 480px; margin: 0 auto; }
.dg-inquiry-row { margin-bottom: 16px; }
.dg-inquiry-row .inq-label {
	font-size: .84rem; font-weight: 600;
	color: var(--dg-text-sub, #64748b); margin-bottom: 6px;
}
.dg-inquiry-row .inq-label .req { color: #e53935; margin-left: 2px; }
.dg-inquiry-row .form-control,
.dg-inquiry-row .form-select {
	font-size: .88rem; border: 1px solid rgba(2,6,23,.12);
	border-radius: 8px; padding: 10px 14px;
}
.dg-inquiry-row .form-control:focus,
.dg-inquiry-row .form-select:focus {
	border-color: #8ca078; box-shadow: 0 0 0 3px rgba(140,176,120,.15); outline: none;
}
.dg-inquiry-row .tel-group { display: flex; align-items: center; gap: 6px; }
.dg-inquiry-row .tel-group .sep { color: var(--dg-text-muted, #94a3b8); font-weight: 600; }
.dg-inquiry-row .tel-group .form-control,
.dg-inquiry-row .tel-group .form-select { flex: 1; min-width: 0; }
.dg-inquiry-submit { text-align: center; margin-top: 24px; }

/* =============================================
   7. RESULT / EMPTY / MESSAGE
============================================= */
.dg-result-card {
	margin-bottom: 1rem;
	border: 1px solid rgba(2,6,23,.08);
	border-radius: 12px;
	overflow: hidden;
}
.dg-result-card__status {
	display: flex; align-items: center; gap: 8px;
	padding: 14px 20px; font-size: .92rem; font-weight: 700;
}
.dg-result-card__status.st-accept { background: rgba(140,176,120,.12); color: #2d4a1e; }
.dg-result-card__status.st-approved { background: #e3f2fd; color: #1565c0; }
.dg-result-card__status.st-cancel { background: #fce4ec; color: #c62828; }

.dg-result-msg {
	padding: 18px 24px; font-size: .88rem; line-height: 1.7;
	color: var(--dg-text-sub, #64748b); border-top: 1px solid rgba(2,6,23,.06);
}
.dg-result-msg strong { color: #3d5a2e; font-weight: 700; }

.dg-empty-result { text-align: center; padding: 60px 20px; }
.dg-empty-result i { display: block; font-size: 40px; color: rgba(140,176,120,.25); margin-bottom: 14px; }
.dg-empty-result p { font-size: .95rem; color: var(--dg-text-muted, #94a3b8); margin-bottom: 16px; }

/* =============================================
   8. FORM SECTION / AGREE
============================================= */
.dg-form-section {
	margin-bottom: 28px;
}
.dg-form-section__title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: .88rem; font-weight: 700;
	color: var(--dg-text, #1e293b);
	margin-bottom: 16px; padding-bottom: 10px;
	border-bottom: 2px solid rgba(140,176,120,.3);
}
.dg-form-section__title i {
	width: 26px; height: 26px;
	background: rgba(140,176,120,.15); color: #3d5a2e;
	border-radius: 6px;
	display: inline-flex; align-items: center; justify-content: center;
	font-size: .75rem; flex-shrink: 0;
}
.dg-agree-box {
	background: #f8fafc;
	border: 1px solid rgba(2,6,23,.08);
	border-radius: 10px;
	padding: 18px 20px;
	margin-bottom: 14px;
}
.dg-agree-box textarea {
	width: 100%;
	border: 1px solid rgba(2,6,23,.1);
	border-radius: 8px;
	padding: 14px 16px;
	font-size: .82rem; line-height: 1.7;
	color: var(--dg-text-sub, #64748b);
	background: #fff;
	resize: vertical;
	font-family: 'Pretendard', sans-serif;
}
.dg-agree-box textarea:focus {
	outline: none;
	border-color: #8ca078;
	box-shadow: 0 0 0 3px rgba(140,176,120,.12);
}
.dg-agree-box.warn textarea {
	border-color: #fca5a5;
	background: #fef2f2;
	color: #c62828;
	font-weight: 600;
	font-size: 1.1rem;
}
.dg-agree-result {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 12px 16px;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	border-radius: 8px;
	margin-top: 10px;
	font-size: .84rem; font-weight: 600;
	color: #1e40af;
	flex-wrap: wrap;
}
.dg-agree-result .agree-text {
	flex: 1; min-width: 200px;
}
.dg-agree-result .form-check-input:checked {
	background-color: #3d5a2e;
	border-color: #3d5a2e;
}
.dg-agree-result .form-check-label {
	font-size: .84rem; font-weight: 500;
	color: var(--dg-text, #1e293b);
}

/* =============================================
   9. FLOATING FORM
============================================= */
.dg-floating-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.dg-fl-row {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.dg-fl-cols-2 {
	flex-direction: row;
	gap: 14px;
}
.dg-fl-cols-2 > * {
	flex: 1; min-width: 0;
}
.dg-floating-form .form-floating > .form-control,
.dg-floating-form .form-floating > .form-select {
	font-family: 'Pretendard', sans-serif;
	font-size: .88rem;
	border: 1px solid rgba(2,6,23,.12);
	border-radius: 10px;
	height: 54px;
	padding: 20px 14px 6px;
}
.dg-floating-form .form-floating > .form-control:focus,
.dg-floating-form .form-floating > .form-select:focus {
	border-color: #8ca078;
	box-shadow: 0 0 0 3px rgba(140,176,120,.15);
}
.dg-floating-form .form-floating > label {
	font-family: 'Pretendard', sans-serif;
	font-size: .84rem; font-weight: 600;
	color: var(--dg-text-muted, #94a3b8);
	padding: 14px 14px;
}
.dg-floating-form .form-floating > .form-control:focus ~ label,
.dg-floating-form .form-floating > .form-control:not(:placeholder-shown) ~ label,
.dg-floating-form .form-floating > .form-select ~ label {
	color: #3d5a2e;
	font-size: .72rem; font-weight: 700;
	transform: scale(.85) translateY(-.6rem) translateX(.1rem);
}
.dg-floating-form .form-floating > .form-control[readonly] {
	background: #f8fafc;
	color: var(--dg-text-sub, #64748b);
}
.dg-fl-label-static {
	font-size: .78rem; font-weight: 700;
	color: #3d5a2e;
	margin-bottom: 4px;
	display: block;
}
.dg-fl-inline {
	display: flex;
	align-items: center;
	gap: 6px;
	flex-wrap: wrap;
}
.dg-fl-inline .form-control,
.dg-fl-inline .form-select {
	font-family: 'Pretendard', sans-serif;
	font-size: .88rem;
	border: 1px solid rgba(2,6,23,.12);
	border-radius: 10px;
	padding: 8px 12px;
	flex: 1; min-width: 0;
}
.dg-fl-inline .form-control:focus,
.dg-fl-inline .form-select:focus {
	border-color: #8ca078;
	box-shadow: 0 0 0 3px rgba(140,176,120,.15);
}
.dg-fl-sep {
	color: var(--dg-text-muted, #94a3b8);
	font-weight: 600;
	flex-shrink: 0;
}

/* =============================================
   10. STEP WIZARD
============================================= */
.step-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0;
	margin-bottom: 28px;
}
.step-item {
	display: flex;
	align-items: center;
	gap: 8px;
}
.step-dot {
	width: 32px; height: 32px;
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	font-size: .78rem; font-weight: 700;
	background: #e2e8f0;
	color: var(--dg-text-muted, #94a3b8);
	transition: all .3s;
}
.step-dot.active,
.step-dot.done {
	background: #3d5a2e;
	color: #fff;
}
.step-label {
	font-size: .82rem; font-weight: 600;
	color: var(--dg-text-muted, #94a3b8);
}
.step-label.active {
	color: var(--dg-text, #1e293b);
}
.step-line {
	width: 40px; height: 2px;
	background: #e2e8f0;
	margin: 0 12px;
}
.step-line.done {
	background: #3d5a2e;
}
.step-panel {
	display: none;
}
.step-panel.is-active {
	display: block;
}

/* 선택 요약 */
.selected-summary {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 18px;
	background: rgba(140,176,120,.08);
	border: 1px solid rgba(140,176,120,.2);
	border-radius: 10px;
	margin-bottom: 20px;
	font-size: .88rem;
	flex-wrap: wrap;
}
.selected-summary .badge-sel {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 5px 12px;
	background: #3d5a2e;
	color: #fff;
	border-radius: 6px;
	font-size: .82rem; font-weight: 600;
}

/* 스텝 하단 버튼 */
.step-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding-top: 20px;
	border-top: 1px solid rgba(2,6,23,.06);
	margin-top: 28px;
}
.step-actions .btn {
	font-family: 'Pretendard', sans-serif;
	font-size: .88rem; font-weight: 600;
	padding: 9px 24px;
	border-radius: 8px;
}
.step-actions .btn-success {
	background: #3d5a2e; border-color: #3d5a2e;
}
.step-actions .btn-success:hover {
	background: #2d4a1e; border-color: #2d4a1e;
}

/* =============================================
   11. CALENDAR (step1)
============================================= */
.step1-layout {
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.step1-cal {
	flex: 0 0 380px;
}
.step1-info {
	flex: 1; min-width: 0;
	background: #f8fafc;
	border: 1px solid rgba(2,6,23,.06);
	border-radius: 12px;
	padding: 20px;
	min-height: 300px;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.mini-cal {
	max-width: 380px;
}
.mini-cal__nav {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin-bottom: 16px;
}
.mini-cal__nav .cal-btn {
	background: none;
	border: 1px solid rgba(2,6,23,.1);
	border-radius: 8px;
	width: 34px; height: 34px;
	display: flex; align-items: center; justify-content: center;
	cursor: pointer;
	color: var(--dg-text-sub, #64748b);
	transition: all .2s;
}
.mini-cal__nav .cal-btn:hover {
	background: rgba(140,176,120,.08);
	border-color: rgba(140,176,120,.25);
	color: #3d5a2e;
}
.mini-cal__nav .cal-title {
	font-size: 1.05rem; font-weight: 700;
	color: var(--dg-text, #1e293b);
}
.mini-cal__grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	gap: 4px;
	text-align: center;
}
.mini-cal__grid .day-head {
	font-size: .72rem; font-weight: 600;
	color: var(--dg-text-muted, #94a3b8);
	padding: 8px 0;
}
.mini-cal__grid .day-head:first-child { color: #ef4444; }
.mini-cal__grid .day-head:last-child { color: #3b82f6; }
.mini-cal__grid .day-cell {
	position: relative;
	aspect-ratio: 1;
	display: flex; align-items: center; justify-content: center;
	font-size: .88rem; font-weight: 500;
	border-radius: 10px;
	cursor: pointer;
	transition: all .2s;
	color: var(--dg-text, #1e293b);
}
.mini-cal__grid .day-cell:hover:not(.disabled):not(.empty) {
	background: rgba(140,176,120,.12);
	color: #2d4a1e;
}
.mini-cal__grid .day-cell.today { background: rgba(140,176,120,.1); font-weight: 700; }
.mini-cal__grid .day-cell.selected { background: #3d5a2e; color: #fff; font-weight: 700; }
.mini-cal__grid .day-cell.disabled { color: var(--dg-text-muted, #94a3b8); opacity: .4; cursor: default; }
.mini-cal__grid .day-cell.empty { cursor: default; }
.mini-cal__grid .day-cell.sun { color: #ef4444; }
.mini-cal__grid .day-cell.sat { color: #3b82f6; }
.mini-cal__grid .day-cell.has-booking::after {
	content: '';
	display: block;
	width: 5px; height: 5px;
	background: #ef4444;
	border-radius: 50%;
	position: absolute;
	bottom: 4px; left: 50%;
	transform: translateX(-50%);
}

/* =============================================
   12. EXPERIENCE CARDS (step2)
============================================= */
.exp-select-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 14px;
}
.exp-select-card {
	background: #fff;
	border: 1px solid rgba(2,6,23,.08);
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
	transition: all .25s;
	text-decoration: none;
	color: var(--dg-text, #1e293b);
}
.exp-select-card:hover {
	box-shadow: 0 4px 16px rgba(2,6,23,.08);
	transform: translateY(-2px);
	border-color: rgba(140,176,120,.3);
}
.exp-select-card__img {
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	background: #f1f5f9;
	display: flex; align-items: center; justify-content: center;
}
.exp-select-card__img img { width: 100%; height: 100%; object-fit: cover; }
.exp-select-card__img .no-img { font-size: 2rem; color: rgba(2,6,23,.1); }
.exp-select-card__body { padding: 14px 16px; }
.exp-select-card__name { font-size: .95rem; font-weight: 700; margin: 0 0 6px; }
.exp-select-card__desc { font-size: .78rem; color: var(--dg-text-sub, #64748b); margin: 0 0 8px; line-height: 1.5; }
.exp-select-card__btn {
	display: block;
	text-align: center;
	padding: 10px;
	background: rgba(140,176,120,.08);
	color: #3d5a2e;
	font-size: .84rem; font-weight: 600;
	border-top: 1px solid rgba(2,6,23,.06);
	transition: all .2s;
}
.exp-select-card:hover .exp-select-card__btn { background: #3d5a2e; color: #fff; }

/* 예약현황 슬롯 */
.booking-slot {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	background: #fef2f2;
	border: 1px solid #fecaca;
	border-radius: 8px;
	font-size: .78rem;
	color: #c62828;
	font-weight: 500;
	margin: 0 6px 6px 0;
}
.booking-slot i { font-size: .7rem; }
.booking-slot .slot-time { font-weight: 700; }

/* 세부 체험 카드 */
.exp-detail-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 12px;
}
.exp-detail-card {
	background: #fff;
	border: 2px solid rgba(2,6,23,.08);
	border-radius: 12px;
	overflow: hidden;
	cursor: pointer;
	transition: all .25s;
	text-align: center;
}
.exp-detail-card:hover {
	border-color: rgba(140,176,120,.4);
	box-shadow: 0 4px 12px rgba(2,6,23,.06);
	transform: translateY(-2px);
}
.exp-detail-card.is-selected {
	border-color: #3d5a2e;
	background: rgba(140,176,120,.05);
}
.exp-detail-card__img {
	width: 100%;
	aspect-ratio: 4/3;
	overflow: hidden;
	background: #f1f5f9;
	display: flex; align-items: center; justify-content: center;
}
.exp-detail-card__img img { width: 100%; height: 100%; object-fit: cover; }
.exp-detail-card__img .no-img { font-size: 1.5rem; color: rgba(2,6,23,.1); }
.exp-detail-card__body { padding: 12px; }
.exp-detail-card__name { font-size: .84rem; font-weight: 600; color: var(--dg-text, #1e293b); margin: 0 0 4px; }
.exp-detail-card__price { font-size: .88rem; font-weight: 700; color: #3d5a2e; }

/* =============================================
   13. VIEW STATUS / MESSAGE / ACTIONS
============================================= */
.dg-view-status {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 16px 24px;
	border-radius: 12px;
	font-size: .95rem; font-weight: 700;
	margin-bottom: 24px;
}
.dg-view-status i { font-size: 1.1rem; }
.dg-view-status.st-accept { background: rgba(140,176,120,.12); color: #2d4a1e; border: 1px solid rgba(140,176,120,.25); }
.dg-view-status.st-confirm { background: #e3f2fd; color: #1565c0; border: 1px solid #bbdefb; }
.dg-view-status.st-unconfirm { background: #fff3e0; color: #e65100; border: 1px solid #ffe0b2; }
.dg-view-status.st-cancel { background: #fce4ec; color: #c62828; border: 1px solid #f8bbd0; }

.dg-view-msg {
	background: #f8fafc;
	border: 1px solid rgba(2,6,23,.06);
	border-radius: 10px;
	padding: 18px 22px;
	font-size: .88rem; line-height: 1.7;
	color: var(--dg-text-sub, #64748b);
	margin-bottom: 24px;
}
.dg-view-msg strong { color: #3d5a2e; font-weight: 700; }
.dg-view-msg .tel { color: var(--dg-text, #1e293b); font-weight: 700; }

.dg-view-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-wrap: wrap;
	padding-top: 20px;
	border-top: 1px solid rgba(2,6,23,.06);
}
.dg-view-actions .btn {
	font-family: 'Pretendard', sans-serif;
	font-size: .84rem; font-weight: 600;
	padding: 8px 16px;
	border-radius: 8px;
	transition: all .2s;
}
.dg-view-actions .btn-success { background: #3d5a2e; border-color: #3d5a2e; }
.dg-view-actions .btn-success:hover { background: #2d4a1e; border-color: #2d4a1e; }
.dg-view-actions .btn-outline-secondary { border-color: rgba(2,6,23,.15); color: var(--dg-text-sub, #64748b); }
.dg-view-actions .btn-outline-secondary:hover { background: #f1f5f9; border-color: rgba(2,6,23,.2); }
.dg-view-actions .actions-left { margin-right: auto; }

/* =============================================
   14. BS5 OVERRIDE
============================================= */
.dg-info-card__body .btn-success,
.dg-academy-card__body .btn-success {
	background: #3d5a2e; border-color: #3d5a2e;
	font-family: 'Pretendard', sans-serif; font-weight: 600; border-radius: 8px;
}
.dg-info-card__body .btn-success:hover,
.dg-academy-card__body .btn-success:hover {
	background: #2d4a1e; border-color: #2d4a1e;
	box-shadow: 0 2px 8px rgba(61,90,46,.25);
}
.dg-info-card__body .btn-outline-secondary,
.dg-academy-card__body .btn-outline-secondary {
	font-family: 'Pretendard', sans-serif; font-weight: 500; border-radius: 8px;
	border-color: rgba(2,6,23,.15); color: var(--dg-text-sub, #64748b);
}
.dg-info-card__body .btn-outline-secondary:hover,
.dg-academy-card__body .btn-outline-secondary:hover {
	background: #f1f5f9; border-color: rgba(2,6,23,.2);
}

/* =============================================
   15. MOBILE
============================================= */
@media (max-width: 767px) {
	/* info-card */
	.dg-info-card__head { gap: .6rem; padding: .7rem .9rem; }
	.dg-info-card__icon { width: 32px; height: 32px; font-size: .9rem; border-radius: 8px; }
	.dg-info-card__title { font-size: .92rem; white-space: normal; word-break: keep-all; }
	.dg-info-card__label { display: none; }
	.dg-info-card__body { padding: 1rem .85rem; }

	/* academy-card */
	.dg-academy-card__head { gap: .6rem; padding: .7rem .9rem; }
	.dg-academy-card__icon { width: 32px; height: 32px; font-size: .9rem; border-radius: 8px; }
	.dg-academy-card__title { font-size: .92rem; white-space: normal; word-break: keep-all; }
	.dg-academy-card__label { display: none; }
	.dg-academy-card__body { padding: 1rem .85rem; }

	/* 툴바 */
	.dg-board-toolbar { gap: 8px; flex-direction: column; }
	.dg-admin-btns { width: 100%; }
	.dg-board-search { margin-left: 0; width: 100%; flex-wrap: wrap; gap: 4px; }
	.dg-board-search .form-control { flex: 1; width: auto; min-width: 0; font-size: .78rem; }
	.dg-board-search .form-select { flex: 0 0 70px; min-width: 0; font-size: .78rem; padding: 6px 8px; }
	.dg-board-search .btn { padding: 6px 8px; font-size: .75rem; }

	/* 필터 */
	.dg-filter-bar { gap: 4px; }
	.dg-filter-bar .btn { font-size: .72rem; padding: 4px 8px; }

	/* 테이블 — 내부 스크롤 */
	.fee-scroll .dg-table,
	.fee-scroll .dg-mgmt-table { min-width: 680px; width: 680px; }
	.fee-scroll .dg-result-table { min-width: 480px; width: 480px; }
	.dg-table, .dg-mgmt-table, .dg-result-table { font-size: .78rem; }
	.dg-table th, .dg-table td,
	.dg-mgmt-table th, .dg-mgmt-table td,
	.dg-result-table th, .dg-result-table td { padding: 8px 8px; }
	.dg-table .status-form,
	.dg-mgmt-table .status-form { flex-wrap: wrap; gap: 4px; }
	.dg-result-table th { width: 80px; font-size: .78rem; padding: 10px 12px; }
	.dg-result-table td { padding: 10px 12px; }

	/* 페이지네이션 */
	.dg-pagination-row { gap: 8px; flex-wrap: wrap; }
	.dg-pagination-row .pagebox01 { gap: 4px; }
	.dg-pagination-row .pagebox01 a, .dg-pagination-row .pagebox01 span,
	.dg-pagination-row .pagebox01 strong, .dg-pagination-row .pagebox01 font { min-width: 30px; height: 30px; padding: 0 8px; font-size: .78rem; }
	.dg-pagination-row > .btn { height: 30px; padding: 0 10px; font-size: .78rem; }

	/* 스텝 */
	.step-line { width: 20px; margin: 0 6px; }
	.step-label { font-size: .72rem; }

	/* 달력 */
	.step1-layout { flex-direction: column; gap: 16px; }
	.step1-cal { flex: none; width: 100%; }
	.step1-info { min-height: auto; width: 100%; box-sizing: border-box; }
	.mini-cal { max-width: 100%; }

	/* 체험카드 */
	.exp-select-grid { grid-template-columns: 1fr; gap: 10px; }
	.exp-detail-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }

	/* 스텝 액션 */
	.step-actions { flex-direction: column-reverse; }
	.step-actions .btn { width: 100%; }

	/* 폼 */
	.dg-fl-cols-2 { flex-direction: column; gap: 16px; }
	.dg-fl-inline .form-select { max-width: none !important; }

	/* 동의 */
	.dg-agree-box textarea { font-size: .78rem; }
	.dg-agree-box.warn textarea { font-size: .82rem; }
	.dg-agree-result { flex-direction: column; align-items: flex-start; gap: 10px; }
	.dg-agree-result .agree-text { min-width: auto; width: 100%; }

	/* 상세 */
	.dg-view-status { padding: 14px 18px; font-size: .88rem; }
	.dg-view-actions { gap: 6px; }
	.dg-view-actions .btn { padding: 7px 12px; font-size: .8rem; }

	/* 결과 카드 */
	.dg-result-msg { padding: 14px 16px; }
	.dg-result-card__status { padding: 12px 16px; font-size: .85rem; }
}

@media print {
	.noprint { display: none !important; }
}