/* ================= Info Page (소개/요금 카드) ================= */
/*이용요금,소개카드 */
.info-features{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-top:12px;
}

.feature-row{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
}

.feature-row .badge{
  flex:0 0 auto;
  font-weight:900;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  background:#f3f4f6;
  border:1px solid var(--line);
  white-space:nowrap;
  font-family: var(--font-body);
}

.feature-row .txt{
  font-size:14px;
  line-height:1.6;
  color:#111827;
  font-family: var(--font-body);
}

/* 요금 카드 */
.price-cards{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.price-card{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding:14px;
  box-shadow: 0 8px 18px rgba(2,6,23,.05);
}

.price-card .tt{
  font-weight:900;
  margin-bottom:10px;
  letter-spacing:-.01em;
  font-family: var(--font-body);
}

.price-card .rows{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.price-card .row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border-radius:12px;
  background:#f8fafc;
  border:1px solid rgba(229,231,235,.7);
}

.price-card .k{
  color:#334155;
  font-weight:700;
  font-size:13px;
  font-family: var(--font-body);
}

.price-card .v{
  font-weight:900;
  font-size:13px;
  font-family: var(--font-body);
}

/* 반응형 */
@media (max-width: 960px){
  .price-cards{ grid-template-columns:1fr; }
}

/* ================= Info Page Emotional Typography ================= */
.intro-lead{
  font-size:15px;
  line-height:1.8;
  color:#111827;
  font-family: var(--font-body);
}

.intro-lead b{
  font-weight:900;
  letter-spacing:-.01em;
}

/* feature row 안 힌트 */
.feature-row .hint{
  display:inline-block;
  margin-left:6px;
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}

/* 강조(특히 단체실) */
.feature-row.highlight{
  background:#f8fafc;
  border-color:#dbeafe;
  box-shadow: 0 10px 22px rgba(2,6,23,.06);
}

.feature-row.highlight .badge{
  background:#111827;
  color:#fff;
  border-color:#111827;
}

/* 안내/특이사항 박스 */
.callout{
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px;
  background:#fff;
  box-shadow: 0 10px 22px rgba(2,6,23,.05);
}

.callout-title{
  font-family: var(--font-title);
  font-size:14px;
  font-weight:400;
  margin-bottom:8px;
  letter-spacing:-.01em;
}

.callout-list{
  margin:0;
  padding-left:18px;
  line-height:1.75;
}

.callout-list li{
  margin:4px 0;
}

.callout-list b{
  font-weight:900;
  color:#111827;
}


/* ===== 요금표 헤더 정렬 ===== */
.table thead th {
  text-align: center;
  vertical-align: middle;
  font-weight: 700;
  
}
/* ===== 헤더 하단 구분선 ===== */
.table thead {
  border-bottom: 2px solid #cbd5e1;
}
/* 구분 | 비수기 사이 */
.table th:nth-child(2),
.table td:nth-child(2) {
  border-left: 1px solid #e5e7eb;
}
/* ===== 성수기 앞 구분선 ===== */
.table th:nth-child(4),
.table td:nth-child(4) {
  border-left: 1px solid #e5e7eb;
}

/* 성수기 | 비고 사이 (선택사항, 균형용) */
.table th:nth-child(5),
.table td:nth-child(5) {
  border-left: 1px solid #f1f5f9;
}

/* ===== 요금표 행 구분선 ===== */
.table tbody tr {
  border-bottom: 1px solid #e5e7eb; /* 연한 회색 */
}

.table tbody tr:last-child {
  border-bottom: none;
}
/* ===== 요금표 헤더 세로 구분선 ===== */

/* 구분 | 비수기 사이 (1행) */
.table thead tr:first-child th:nth-child(2) {
  border-left: 1px solid #e5e7eb;
}

/* 비수기 | 성수기 사이 (1행) */
.table thead tr:first-child th:nth-child(3) {
  border-left: 1px solid #e5e7eb;
}

/* 주중 | 주말 사이 (2행) */
.table thead tr:nth-child(2) th:nth-child(2) {
  border-left: 1px solid #e5e7eb;
}
/* ===== 헤더: 구분(rowspan) 오른쪽 구분선 ===== */
.table thead th[rowspan] {
  border-right: 1px solid #e5e7eb;
}

/* =========================
   캠핑장 이용안내 요금표 (최종)
   - 중앙정렬 / 선 정리
   - 모바일 가로스크롤바 깨짐(라운드+스크롤 충돌) 해결
========================= */

/* (바깥) 라운드 + 테두리 프레임 */
.price-table-frame{
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #fff;
  overflow: hidden; /* ✅ 라운드 깔끔 */
}

/* (안쪽) 가로 스크롤 담당 */
.price-table-wrap{
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;

  /* ✅ 스크롤바가 내용/라운드랑 겹쳐서 깨지는 것 방지 */
  padding-bottom: 10px;
}

/* 스크롤바 디자인(크롬/엣지/사파리) */
.price-table-wrap::-webkit-scrollbar{
  height: 8px;
}
.price-table-wrap::-webkit-scrollbar-track{
  background: #eef2f7;
  border-radius: 999px;
}
.price-table-wrap::-webkit-scrollbar-thumb{
  background: #cbd5e1;
  border-radius: 999px;
}

/* 테이블 */
.price-table{
  width: 100%;
  border-collapse: collapse; /* ✅ 선 정리 핵심 */
  background: #fff;
  font-size: 14px;
}

/* 헤더 */
.price-table thead th{
  background: #f9fafb;
  font-weight: 800;
  text-align: center;
  vertical-align: middle;
  padding: 12px 10px;

  border-bottom: 2px solid #d1d5db;
  border-right: 1px solid #e5e7eb;

  /* ✅ 헤더 글자 깨짐/줄바꿈 방지 */
  white-space: nowrap;
}
.price-table thead th:last-child{
  border-right: none;
}

/* 바디 */
.price-table tbody td{
  padding: 12px 10px;
  vertical-align: middle;

  border-bottom: 1px solid #e5e7eb;
  border-right: 1px solid #e5e7eb;
}
.price-table tbody td:last-child{
  border-right: none;
}
.price-table tbody tr:last-child td{
  border-bottom: none;
}

/* 첫 컬럼(구분) */
.price-table tbody td:first-child{
  text-align: left;
  font-weight: 700;
  white-space: nowrap;
}

/* 나머지 컬럼(가격 등) 중앙정렬 */
.price-table tbody td:not(:first-child){
  text-align: center;
}

/* 비고는 너무 좁으면 보기 힘드니 줄바꿈 허용 */
.price-table tbody td:last-child{
  text-align: left;           /* 비고는 읽기 좋게 좌측 */
  white-space: normal;        /* ✅ 줄바꿈 허용 */
  line-height: 1.5;
}

/* 안내 문구 */
.price-table-hint{
  text-align: center;
  font-size: 12px;
  color: #8b8378;
  margin-top: 6px;
}

/* 모바일: 테이블은 넓게 두고 스크롤로 보게 */
@media (max-width: 768px){
  .price-table{
    min-width: 640px; /* ✅ 여기 늘려야 “성수기/비고”가 안 뭉개짐 */
  }
}
/* 기본: PC에서는 숨김 */
.price-table-hint{
  display: none;
  text-align: center;
  font-size: 12px;
  color: #8b8378;
  margin-top: 6px;
}

/* 모바일에서만 표시 */
@media (max-width: 768px){
  .price-table-hint{
    display: block;
  }
}
.contact-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 16px;
}
@media (max-width: 768px){
  .contact-row .btn{
    display: none;
  }
}
/* =========================
   ✅ 주말 | 성수기 사이 구분선 (핵심)
   ========================= */

/* 헤더: 성수기 왼쪽 */
.price-table thead th[rowspan="2"]:nth-of-type(3){
  border-left: 1px solid #e5e7eb;
}

/* 바디: 성수기 컬럼 왼쪽 */
.price-table tbody td:nth-child(4){
  border-left: 1px solid #e5e7eb;
}
