/* ===== Base ===== */
*, *::before, *::after { box-sizing: border-box; }
body { font-family: 'Noto Sans KR', -apple-system, sans-serif; background:#f8fafc; color:#1e293b; }

/* ===== Navbar ===== */
.navbar { background:#fff !important; border-bottom:1px solid #e2e8f0; }
.navbar-brand { font-size:1.2rem; font-weight:900; letter-spacing:-.5px; color:#1d4ed8 !important; }
.nav-menu-item { display:block; padding:10px 0; color:#1e293b; font-weight:600; text-decoration:none; font-size:.92rem; }
.nav-menu-item:hover { color:#1d4ed8; }

/* ===== Hero (legacy) ===== */
.hero { background:linear-gradient(135deg,#1d4ed8 0%,#0f2a7a 60%,#1e1b4b 100%); padding:72px 0 64px; text-align:center; color:#fff; }
.hero-title { font-size:clamp(1.8rem,5vw,3rem); font-weight:900; letter-spacing:-1px; margin-bottom:12px; }
.hero-sub   { font-size:1.05rem; opacity:.8; margin-bottom:32px; }
.hero-search .form-control,
.hero-search .form-select { height:52px; font-size:1rem; border:none; box-shadow:0 2px 8px rgba(0,0,0,.15); border-radius:10px; }
.hero-search .btn { height:52px; border-radius:10px; font-weight:700; font-size:1rem; }

/* ===== 아이콘 그리드 (Trip.com 스타일) ===== */
.icon-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:12px;
}
.icon-grid-item {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  text-decoration:none; color:#1e293b; font-size:.75rem; font-weight:600;
  transition:transform .15s; text-align:center; word-break:keep-all;
}
.icon-grid-item:hover { transform:translateY(-2px); color:#1d4ed8; }
.icon-grid-circle {
  width:52px; height:52px; border-radius:14px;
  background:#f0fdf4; color:#16a34a;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; transition:box-shadow .15s;
}
.icon-grid-item:hover .icon-grid-circle { box-shadow:0 4px 12px rgba(0,0,0,.1); }

/* 인기 여행지 pill */
.country-pill {
  display:inline-flex; align-items:center; gap:4px;
  padding:6px 14px; background:#fff; border:1.5px solid #e2e8f0;
  border-radius:999px; font-size:.82rem; font-weight:600;
  color:#475569; text-decoration:none; cursor:pointer;
  transition:all .15s;
}
.country-pill:hover { border-color:#1d4ed8; color:#1d4ed8; background:#eff6ff; }

/* ===== Wizard ===== */
.wizard-section { background:linear-gradient(135deg,#1d4ed8 0%,#0f2a7a 55%,#1e1b4b 100%); padding:48px 0 56px; color:#fff; }
.wz-header { text-align:center; margin-bottom:24px; }
.wz-header h1 { font-size:clamp(1.5rem,4vw,2.2rem); font-weight:900; letter-spacing:-1px; margin-bottom:6px; }
.wz-header p  { font-size:.9rem; opacity:.7; margin:0; }

/* returning user banner */
.wz-returning { display:none; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); border-radius:12px; padding:10px 20px; margin-bottom:20px; text-align:center; font-size:.88rem; }
.wz-returning a { color:#fbbf24; font-weight:700; text-decoration:none; }
.wz-returning a:hover { text-decoration:underline; }

/* progress dots */
.wz-dots { display:flex; justify-content:center; align-items:center; gap:8px; margin-bottom:28px; }
.wdot { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.3); transition:all .3s ease; }
.wdot.active { background:#fbbf24; width:22px; border-radius:4px; }
.wdot.done   { background:rgba(255,255,255,.6); }

/* steps */
@keyframes stepSlideIn { from{opacity:0;transform:translateX(24px)} to{opacity:1;transform:translateX(0)} }
.wz-step { display:none; }
.wz-step.active { display:block; animation:stepSlideIn .3s ease forwards; }

.wz-question { text-align:center; font-size:clamp(1.1rem,3vw,1.45rem); font-weight:800; margin-bottom:6px; }
.wz-hint     { text-align:center; font-size:.82rem; opacity:.65; margin-bottom:16px; }

/* country grid */
.wz-country-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(88px,1fr)); gap:9px; max-width:680px; margin:0 auto 10px; }
.wz-country { display:flex; flex-direction:column; align-items:center; gap:5px; padding:13px 6px; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.18); border-radius:12px; color:#fff; font-size:.78rem; font-weight:600; cursor:pointer; transition:all .15s; }
.wz-country .wz-flag { font-size:1.7rem; line-height:1; }
.wz-country:hover  { background:rgba(251,191,36,.2); border-color:rgba(251,191,36,.6); }
.wz-country.sel    { background:rgba(251,191,36,.28); border-color:#fbbf24; }

/* city grid */
.wz-city-grid { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; max-width:620px; margin:0 auto 10px; }
.wz-city { display:flex; flex-direction:column; align-items:center; gap:4px; padding:10px 14px; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.18); border-radius:14px; color:#fff; font-size:.8rem; font-weight:600; cursor:pointer; transition:all .15s; min-width:72px; }
.wz-city-em { font-size:1.5rem; line-height:1; }
.wz-city:hover { background:rgba(251,191,36,.2); border-color:rgba(251,191,36,.6); }
.wz-city.sel   { background:rgba(251,191,36,.28); border-color:#fbbf24; }
.wz-city-more { padding:8px 18px; background:rgba(255,255,255,.08); border:1.5px dashed rgba(255,255,255,.3); border-radius:20px; color:rgba(255,255,255,.7); font-size:.8rem; cursor:pointer; transition:all .15s; }
.wz-city-more:hover { background:rgba(255,255,255,.15); color:#fff; }

/* companion grid */
.wz-comp-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; max-width:560px; margin:0 auto 10px; }
@media(max-width:480px){ .wz-comp-grid{grid-template-columns:repeat(2,1fr);} }
.wz-comp { display:flex; flex-direction:column; align-items:center; gap:8px; padding:22px 10px; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.18); border-radius:16px; color:#fff; cursor:pointer; transition:all .18s; }
.wz-comp .wz-ci { font-size:2.4rem; line-height:1; }
.wz-comp .wz-cl { font-size:.88rem; font-weight:700; }
.wz-comp:hover  { background:rgba(251,191,36,.2); border-color:rgba(251,191,36,.6); transform:translateY(-2px); }
.wz-comp.sel    { background:rgba(251,191,36,.28); border-color:#fbbf24; transform:translateY(-2px); }

/* theme pills */
.wz-theme-grid { display:flex; flex-wrap:wrap; gap:9px; justify-content:center; max-width:620px; margin:0 auto 22px; }
.wz-theme { padding:8px 18px; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.22); border-radius:999px; color:#fff; font-size:.83rem; font-weight:600; cursor:pointer; transition:all .15s; }
.wz-theme:hover { background:rgba(255,255,255,.18); }
.wz-theme.sel   { background:#fbbf24; border-color:#fbbf24; color:#1e1b4b; }

/* CTA */
.wz-cta { text-align:center; margin-top:4px; }
.btn-wz-go { display:inline-block; padding:14px 44px; background:#fbbf24; color:#1e1b4b; border:none; border-radius:12px; font-size:1.05rem; font-weight:900; cursor:pointer; transition:all .2s; letter-spacing:-.3px; }
.btn-wz-go:hover { background:#f59e0b; transform:translateY(-2px); box-shadow:0 8px 24px rgba(251,191,36,.45); }
.wz-sel-summary { margin-top:10px; font-size:.82rem; opacity:.65; min-height:18px; }

/* nav (back / skip) */
.wz-nav { display:flex; justify-content:center; gap:20px; margin-top:14px; }
.wz-back,.wz-skip { background:none; border:none; color:rgba(255,255,255,.55); font-size:.8rem; cursor:pointer; padding:4px 8px; transition:color .15s; }
.wz-back:hover,.wz-skip:hover { color:#fff; }

/* ===== Section ===== */
.section-header  { display:flex; align-items:baseline; justify-content:space-between; margin-bottom:8px; }
.section-title   { font-size:1.4rem; font-weight:800; letter-spacing:-.5px; margin-bottom:0; }
.section-more    { font-size:.9rem; color:#2563eb; text-decoration:none; font-weight:600; white-space:nowrap; }
.section-more:hover { text-decoration:underline; }

/* ===== Tag Pills ===== */
.tag-pill { display:inline-block; padding:5px 14px; background:#fff; border:1.5px solid #cbd5e1; border-radius:999px; font-size:.82rem; font-weight:600; color:#475569; text-decoration:none; transition:all .15s; }
.tag-pill:hover { background:#1d4ed8; border-color:#1d4ed8; color:#fff; }
.tag-badge { display:inline-block; padding:2px 9px; background:#e0f2fe; color:#0369a1; border-radius:999px; font-size:.72rem; font-weight:600; text-decoration:none; margin-right:3px; margin-bottom:3px; }
.tag-badge:hover { background:#bae6fd; }
.tag-badge-lg { font-size:.82rem; padding:4px 12px; }

/* ===== Destination / Theme / City Cards ===== */
.dest-card { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:20px 12px; background:#fff; border-radius:16px; border:1.5px solid #e2e8f0; text-decoration:none; text-align:center; transition:all .2s; height:100%; }
.dest-card:hover { border-color:#1d4ed8; transform:translateY(-3px); box-shadow:0 8px 24px rgba(29,78,216,.12); }
.dest-flag  { font-size:2.2rem; line-height:1; margin-bottom:8px; }
.dest-name  { font-size:.95rem; font-weight:700; color:#1e293b; }
.dest-count { font-size:.75rem; color:#94a3b8; margin-top:2px; }

.theme-card  { display:flex; align-items:center; gap:14px; padding:16px 20px; border-radius:14px; border:1px solid #e2e8f0; text-decoration:none; transition:all .2s; }
.theme-card:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,.1); }
.theme-icon  { font-size:2rem; flex-shrink:0; }
.theme-name  { font-weight:700; font-size:.95rem; }
.theme-count { font-size:.78rem; color:#64748b; margin-top:2px; }

.city-card { display:block; padding:18px 14px; background:#fff; border:1.5px solid #e2e8f0; border-radius:12px; text-align:center; text-decoration:none; transition:all .2s; }
.city-card:hover { border-color:#2563eb; background:#eff6ff; transform:translateY(-2px); }
.city-name  { font-weight:700; font-size:.95rem; color:#1e293b; }
.city-count { font-size:.78rem; color:#94a3b8; margin-top:3px; }

/* ===== Filter Panel ===== */
.filter-panel { background:#fff; border:1px solid #e2e8f0; border-radius:14px; padding:20px; box-shadow:0 1px 4px rgba(0,0,0,.06); }

/* 활성 필터 배지 바 */
.active-filter-bar { display:flex; align-items:center; flex-wrap:wrap; gap:8px; padding:10px 14px; background:#eff6ff; border:1.5px solid #bfdbfe; border-radius:10px; margin-bottom:12px; }

/* 마법사 요약 바 */
.wizard-summary-bar { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px; padding:12px 16px; background:linear-gradient(135deg,#eff6ff,#f0fdf4); border:1.5px solid #bfdbfe; border-radius:12px; }
.wsb-chips { display:flex; flex-wrap:wrap; gap:6px; }
.wsb-chip { padding:4px 12px; background:#fff; border:1.5px solid #93c5fd; border-radius:20px; font-size:.82rem; font-weight:600; color:#1d4ed8; }
.wsb-toggle { padding:6px 14px; background:#2563eb; border:none; border-radius:20px; color:#fff; font-size:.82rem; font-weight:600; cursor:pointer; white-space:nowrap; transition:background .15s; }
.wsb-toggle:hover { background:#1d4ed8; }

/* 카드/지도 뷰 토글 */
.view-toggle-wrap { display:flex; border:1.5px solid #e2e8f0; border-radius:8px; overflow:hidden; }
.view-btn { padding:5px 14px; border:none; background:#fff; font-size:.82rem; font-weight:600; color:#64748b; cursor:pointer; transition:all .15s; }
.view-btn:hover  { background:#f1f5f9; }
.view-btn.active { background:#1d4ed8; color:#fff; }
.af-label { font-size:.75rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.4px; }
.af-chip { display:inline-flex; align-items:center; gap:4px; padding:5px 12px; background:#1d4ed8; color:#fff; border:none; border-radius:999px; font-size:.82rem; font-weight:700; cursor:pointer; transition:background .15s; }
.af-chip:hover { background:#1e40af; }
.filter-label  { font-size:.78rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.5px; margin-bottom:4px; display:block; }

/* 일행 버튼 */
.companion-btn { padding:7px 16px; border:2px solid #e2e8f0; border-radius:999px; background:#fff; font-size:.85rem; font-weight:600; color:#475569; cursor:pointer; transition:all .15s; }
.companion-btn:hover  { border-color:#1d4ed8; color:#1d4ed8; }
.companion-btn.active { background:#1d4ed8; border-color:#1d4ed8; color:#fff; }

/* 국가/도시 pill */
.cpill-wrap { display:flex; flex-wrap:wrap; gap:7px; }
.cpill { padding:6px 13px; border:1.5px solid #e2e8f0; border-radius:999px; background:#fff; font-size:.83rem; font-weight:600; color:#475569; cursor:pointer; transition:all .15s; white-space:nowrap; }
.cpill:hover  { border-color:#1d4ed8; color:#1d4ed8; background:#eff6ff; }
.cpill.active { background:#1d4ed8; border-color:#1d4ed8; color:#fff; }

/* 테마 버튼 */
.theme-btn { padding:6px 14px; border:2px solid #e2e8f0; border-radius:999px; background:#fff; font-size:.8rem; font-weight:600; color:#475569; cursor:pointer; transition:all .15s; }
.theme-btn:hover  { border-color:#0ea5e9; color:#0ea5e9; }
.theme-btn.active { background:#0ea5e9; border-color:#0ea5e9; color:#fff; }
.theme-btn .tag-cnt { font-size:.7rem; opacity:.7; }

/* ===== Hotel Card ===== */
.hotel-card { display:flex; flex-direction:column; background:#fff; border:1.5px solid #e2e8f0; border-radius:16px; overflow:hidden; transition:all .2s; cursor:pointer; }
.hotel-card:hover { border-color:#93c5fd; box-shadow:0 6px 24px rgba(29,78,216,.1); }

/* 이미지 */
.hotel-card-img { width:100%; height:180px; object-fit:cover; display:block; }
.hotel-img-link { display:block; overflow:hidden; }
.hotel-img-placeholder { width:100%; height:160px; background:linear-gradient(135deg,#e0f2fe,#bfdbfe); display:flex; align-items:center; justify-content:center; font-size:2.5rem; font-weight:900; color:#3b82f6; }
.hotel-img-placeholder.sm { height:120px; font-size:2rem; }

.hotel-card-body   { padding:16px 16px 8px; flex:1; }
.hotel-card-footer { padding:10px 16px 14px; border-top:1px solid #f1f5f9; }

/* 카드 액션 바 (좋아요 + 댓글 + 공유 + 즐겨찾기) */
.card-actions {
  display:flex; align-items:center; gap:12px; font-size:.92rem;
}
.card-actions .like-count-val,
.card-actions span.ms-1 { font-size:.78rem; color:#64748b; }
.card-actions .btn-link { color:#64748b; }
.card-actions .btn-link:hover { color:#1d4ed8; }
.card-compare-btn { font-size:.75rem !important; font-weight:600 !important; color:#3b82f6 !important; }

/* 카드 상단줄: 위치 + 평점 */
.hotel-card-topline {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:4px;
}
.review-chip {
  display:inline-flex; align-items:center; justify-content:center;
  background:#1d4ed8; color:#fff;
  font-size:.75rem; font-weight:700;
  padding:2px 8px; border-radius:6px;
  min-width:32px; flex-shrink:0;
}

.hotel-location  { font-size:.78rem; font-weight:600; color:#64748b; }
.hotel-name      { font-size:.97rem; font-weight:800; line-height:1.35; margin-bottom:4px; }
.hotel-name a    { color:#1e293b; text-decoration:none; }
.hotel-name a:hover { color:#1d4ed8; }
.hotel-name-en   { font-size:.78rem; color:#64748b; margin-bottom:6px; }
.hotel-desc      { font-size:.8rem; color:#475569; line-height:1.5; margin-bottom:6px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.hotel-stats     { display:flex; gap:10px; font-size:.78rem; color:#64748b; }

/* ===== 소셜 프루프 뱃지 ===== */
.card-social-badge {
  position:absolute; top:10px; left:10px; z-index:3;
  background:rgba(0,0,0,.65); color:#fff;
  font-size:.7rem; font-weight:600;
  padding:3px 8px; border-radius:6px;
  backdrop-filter:blur(4px);
  pointer-events:none;
}

/* ===== 즐겨찾기 버튼 ===== */
.btn-fav { border:1.5px solid #e2e8f0; background:#fff; font-size:.8rem; padding:3px 8px; }
.btn-fav:hover { border-color:#f59e0b; }

/* ===== Booking Buttons ===== */
.btn-book    { color:#fff !important; font-weight:700; font-size:.88rem; border-radius:10px; padding:9px 16px; transition:opacity .15s, transform .1s; }
.btn-book:hover { opacity:.9; transform:translateY(-1px); color:#fff; }
.btn-book-lg { color:#fff !important; font-weight:800; font-size:1.05rem; border-radius:12px; padding:14px 20px; transition:opacity .15s, transform .1s; }
.btn-book-lg:hover { opacity:.9; transform:translateY(-1px); color:#fff; }
.btn-platform { background:#fff; font-weight:700; font-size:.88rem; border-radius:10px; padding:9px 16px; border-width:2px; transition:all .15s; }
.btn-platform:hover { opacity:.85; }
.platform-toggle-btn { font-size:.82rem; }
@media (min-width:992px) { .d-lg-grid { display:grid !important; } }

/* ===== Booking Panel ===== */
.booking-panel          { background:#fff; border:1.5px solid #e2e8f0; border-radius:18px; overflow:hidden; box-shadow:0 4px 24px rgba(0,0,0,.08); }
.booking-panel-header   { background:#f8fafc; color:#1e293b; padding:16px 22px; border-bottom:1px solid #e2e8f0; }
.booking-panel-body     { padding:20px 22px; }
.affiliate-notice       { background:#f8fafc; border-radius:8px; padding:10px 12px; }

/* ===== Date Range Picker ===== */
.date-range-row         { width:100%; }
.date-range-box         { display:flex; align-items:center; background:#f8fafc; border:1.5px solid #e2e8f0; border-radius:12px; overflow:hidden; transition:border-color .2s; }
.date-range-box:focus-within { border-color:#1d4ed8; box-shadow:0 0 0 3px rgba(29,78,216,.1); }
.date-range-item        { flex:1; padding:10px 14px; cursor:pointer; }
.date-range-label       { font-size:.7rem; font-weight:700; color:#64748b; text-transform:uppercase; letter-spacing:.5px; display:block; margin-bottom:2px; }
.date-range-val         { font-size:.92rem; font-weight:600; color:#1e293b; }
.date-range-arrow       { color:#94a3b8; font-size:1rem; padding:0 4px; flex-shrink:0; }
#fp-range-anchor, #fp-range-anchor + input { display:none !important; }
.date-range-box.selecting-checkout .date-range-item:last-child .date-range-label { color:#1d4ed8; }

/* Flatpickr 커스텀 */
.flatpickr-calendar     { border-radius:16px !important; box-shadow:0 8px 32px rgba(0,0,0,.15) !important; border:1.5px solid #e2e8f0 !important; font-family:'Noto Sans KR',sans-serif !important; }
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover { background:#1d4ed8 !important; border-color:#1d4ed8 !important; color:#fff !important; }
.flatpickr-day.inRange  { background:#dbeafe !important; border-color:#dbeafe !important; color:#1e293b !important; box-shadow:-5px 0 0 #dbeafe, 5px 0 0 #dbeafe !important; }
.flatpickr-day:hover    { background:#eff6ff !important; }
.flatpickr-months       { background:#1d4ed8 !important; border-radius:14px 14px 0 0 !important; padding:4px 0 !important; }
.flatpickr-month        { color:#fff !important; }
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year { color:#fff !important; font-weight:700 !important; }
.flatpickr-prev-month svg, .flatpickr-next-month svg { fill:#fff !important; }
.flatpickr-prev-month:hover svg, .flatpickr-next-month:hover svg { fill:#93c5fd !important; }
.flatpickr-weekday      { color:#1d4ed8 !important; font-weight:700 !important; }
.flatpickr-day.today    { border-color:#1d4ed8 !important; font-weight:700; }
.flatpickr-day.flatpickr-disabled { color:#cbd5e1 !important; }
.flatpickr-calendar.hasTime .flatpickr-time { border-top:1px solid #e2e8f0 !important; }

/* ===== Hotel Detail ===== */
.hotel-detail-img { border-radius:16px; overflow:hidden; max-height:400px; }
.hotel-detail-img img { width:100%; height:100%; object-fit:cover; }
.hotel-detail-card    { background:#fff; border:1.5px solid #e2e8f0; border-radius:18px; padding:28px 32px; }
/* 사진 썸네일 스트립 */
.photo-thumb-strip {
  display:flex; gap:6px; overflow-x:auto;
  scrollbar-width:none; -ms-overflow-style:none;
  padding:2px 0;
}
.photo-thumb-strip::-webkit-scrollbar { display:none; }
.photo-thumb {
  width:64px; height:48px; object-fit:cover; border-radius:8px;
  border:2px solid transparent; cursor:pointer;
  opacity:.6; transition:all .15s; flex-shrink:0;
}
.photo-thumb:hover { opacity:.9; }
.photo-thumb.active { border-color:#1d4ed8; opacity:1; }
.photo-count-badge {
  position:absolute; bottom:10px; right:10px; z-index:3;
  background:rgba(0,0,0,.6); color:#fff;
  font-size:.72rem; font-weight:600;
  padding:2px 8px; border-radius:6px;
  pointer-events:none;
}

.hotel-location-lg    { font-size:.85rem; font-weight:600; color:#64748b; margin-bottom:8px; }
.hotel-detail-name    { font-size:1.8rem; font-weight:900; letter-spacing:-.5px; line-height:1.2; }
.hotel-detail-name-en { font-size:.9rem; }
.detail-stats         { display:flex; gap:16px; flex-wrap:wrap; font-size:.88rem; color:#475569; }
.detail-stats strong  { color:#1e293b; }

.desc-part { font-size:.95rem; color:#334155; line-height:1.7; padding:14px 18px; background:#f8fafc; border-left:3px solid #93c5fd; border-radius:0 8px 8px 0; margin-bottom:10px; }

/* 설명 접기/펼치기 */
.hotel-detail-desc.collapsed { max-height:120px; overflow:hidden; position:relative; }
.hotel-detail-desc.collapsed::after { content:''; position:absolute; bottom:0; left:0; right:0; height:60px; background:linear-gradient(transparent,#fff); }
.btn-desc-toggle { display:block; width:100%; margin-top:4px; padding:8px; background:none; border:1px solid #e2e8f0; border-radius:8px; color:#64748b; font-size:.85rem; cursor:pointer; text-align:center; transition:background .2s; }
.btn-desc-toggle:hover { background:#f8fafc; }

/* 😺 숙소냥이 말풍선 */
.nyang-bubble { display:flex; gap:12px; align-items:flex-start; background:linear-gradient(135deg,#fff8f0,#fff3e6); border:1.5px solid #ffd8a8; border-radius:16px; padding:14px 16px; margin-bottom:16px; position:relative; }
.nyang-bubble::before { content:''; position:absolute; top:18px; left:-10px; border:6px solid transparent; border-right-color:#ffd8a8; }
.nyang-avatar { font-size:2rem; line-height:1; flex-shrink:0; margin-top:2px; }
.nyang-body { flex:1; }
.nyang-name { font-size:.75rem; font-weight:700; color:#e8890c; text-transform:uppercase; letter-spacing:.05em; margin-bottom:4px; }
.nyang-text { font-size:.9rem; color:#4a3728; line-height:1.6; margin:0; }

/* ===== 좋아요 버튼 ===== */
.btn-like       { padding:10px 20px; border:2px solid #e2e8f0; border-radius:999px; background:#fff; font-weight:700; font-size:.95rem; cursor:pointer; transition:all .2s; }
.btn-like:hover { border-color:#ef4444; color:#ef4444; }
.btn-like.liked { background:#fff0f0; border-color:#ef4444; color:#ef4444; }

/* ===== 댓글 ===== */
.comments-section { background:#fff; border:1.5px solid #e2e8f0; border-radius:16px; padding:24px; }
.comment-item    { padding:12px 0; border-bottom:1px solid #f1f5f9; }
.comment-item:last-child { border-bottom:none; }
.comment-meta    { margin-bottom:4px; }
.comment-content { font-size:.9rem; color:#334155; margin:0; line-height:1.6; }
.comment-form    { padding-top:16px; border-top:1px solid #f1f5f9; margin-top:8px; }

/* ===== Country Hero ===== */
.country-hero    { background:#fff; color:#1e293b; text-align:center; padding:40px 0 32px; border-bottom:1px solid #e2e8f0; }
.country-flag-lg { font-size:3rem; margin-bottom:8px; }
.country-title   { font-size:1.8rem; font-weight:900; letter-spacing:-1px; margin-bottom:6px; color:#1e293b; }
.country-sub     { font-size:.92rem; color:#64748b; }

/* ===== Toast ===== */
.tp-toast { position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(20px); background:#1e293b; color:#fff; padding:10px 20px; border-radius:999px; font-size:.88rem; font-weight:600; opacity:0; transition:all .25s; z-index:9999; pointer-events:none; white-space:nowrap; }
.tp-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ===== 실시간 인기 사이드바 ===== */
.popular-sidebar { background:#fff; border:1.5px solid #e2e8f0; border-radius:16px; overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,.07); }
.popular-sidebar-header { background:#fff; color:#1e293b; padding:14px 16px; display:flex; justify-content:space-between; align-items:center; font-weight:800; font-size:.95rem; border-bottom:1px solid #e2e8f0; }
.popular-updated-time { font-size:.72rem; opacity:.75; font-weight:400; }

.rank-item { display:flex; align-items:center; gap:10px; padding:10px 14px; text-decoration:none; color:#1e293b; border-bottom:1px solid #f1f5f9; transition:background .15s; }
.rank-item:last-child { border-bottom:none; }
.rank-item:hover { background:#f8fafc; }
.rank-item-hot { background:#fffbeb; }
.rank-item-hot:hover { background:#fef3c7; }

.rank-badge { width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:.72rem; font-weight:900; flex-shrink:0; }
.rank-badge-1 { background:#f59e0b; color:#fff; }
.rank-badge-2 { background:#94a3b8; color:#fff; }
.rank-badge-3 { background:#cd7c4d; color:#fff; }
.rank-badge-n { background:#f1f5f9; color:#64748b; }

.rank-info { flex:1; min-width:0; }
.rank-name  { font-size:.82rem; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.rank-loc   { font-size:.75rem; color:#64748b; margin-top:1px; }
.rank-stats { font-size:.75rem; color:#64748b; white-space:nowrap; flex-shrink:0; }

.online-bar { padding:8px 14px; background:#f0fdf4; border-bottom:1px solid #e2e8f0; font-size:.78rem; color:#166534; font-weight:600; display:flex; align-items:center; gap:6px; }
.hotel-viewers-bar { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:999px; font-size:.8rem; color:#166534; font-weight:600; margin-bottom:16px; }
.online-dot { width:8px; height:8px; background:#22c55e; border-radius:50%; display:inline-block; animation:pulse-green 1.5s infinite; flex-shrink:0; }
@keyframes pulse-green { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.3)} }

/* ===== Footer ===== */
.footer {}

/* ===== 날짜 선택 / 가격 ===== */
.date-notice    { font-size:.8rem; color:#64748b; padding:8px 12px; background:#f8fafc; border-radius:8px; border:1px solid #e2e8f0; }

/* 카드 가격 배지 */
.price-badge    { display:flex; align-items:center; gap:6px; flex-wrap:wrap; padding:6px 0 4px; border-bottom:1px solid #f1f5f9; margin-bottom:6px; }
.price-amount-sm{ font-size:.95rem; font-weight:900; color:#0f172a; }
.price-night    { font-size:.72rem; font-weight:400; color:#64748b; }
.price-discount { font-size:.72rem; font-weight:700; color:#fff; background:#ef4444; border-radius:4px; padding:1px 5px; }
.price-extras   { font-size:.72rem; color:#64748b; }

/* 상세 페이지 가격 위젯 */
.price-display  { background:linear-gradient(135deg,#f0fdf4,#dcfce7); border:1.5px solid #86efac; border-radius:12px; padding:12px 16px; margin-bottom:12px; }
.price-amount   { font-size:1.6rem; font-weight:900; color:#166534; line-height:1.2; }
.price-meta     { font-size:.82rem; color:#16a34a; margin-top:4px; display:flex; gap:8px; flex-wrap:wrap; align-items:center; }

/* ===== 여행 월 선택기 ===== */
.month-picker-wrap  { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.month-picker-label { font-size:.8rem; font-weight:700; color:#64748b; white-space:nowrap; }
.month-picker       { display:flex; flex-wrap:wrap; gap:4px; }
.month-btn          { padding:4px 10px; border:1.5px solid #e2e8f0; border-radius:999px; background:#fff; font-size:.78rem; font-weight:600; color:#475569; cursor:pointer; transition:all .15s; }
.month-btn:hover    { border-color:#1d4ed8; color:#1d4ed8; }
.month-btn.active   { background:#1d4ed8; border-color:#1d4ed8; color:#fff; }

/* ===== 기후 배지 (국가 카드) ===== */
.climate-badge      { display:inline-block; margin-top:5px; padding:2px 8px; border-radius:999px; font-size:.72rem; font-weight:700; }

/* ===== 필터 기후 배너 ===== */
.filter-climate-bar { align-items:center; gap:8px; padding:8px 14px; border-radius:10px; border:1.5px solid; font-size:.85rem; font-weight:600; margin-bottom:12px; flex-wrap:wrap; }

/* ===== 국가 히어로 기후 배너 ===== */
.country-climate-bar { align-items:center; gap:8px; margin:12px auto 0; padding:10px 20px; border-radius:999px; background:#f1f5f9; color:#475569; font-size:.92rem; font-weight:600; }

/* ===== Opacity helper ===== */
.opacity-50 { opacity:.5; transition:opacity .2s; }

/* ===== Responsive ===== */
@media (max-width:768px) {
  .hero { padding:48px 0 40px; }
  .hotel-detail-card { padding:20px 18px; }
  .hotel-detail-name { font-size:1.4rem; }
  .booking-panel { position:static !important; }
  .detail-stats  { gap:10px; font-size:.82rem; }

  /* 모바일 카드 압축: 영문명 숨기기 */
  .hotel-name-en { display:none; }

  /* 모바일 카드 가격 강조 */
  .card-price {
    font-size:1.05rem !important;
    padding:4px 0;
  }

  /* 모바일 바텀시트 모달 (Trip.com 스타일) */
  .modal-dialog.modal-dialog-centered,
  .modal-dialog.modal-dialog-scrollable {
    margin:0; max-width:100%; align-items:flex-end;
    min-height:100%;
  }
  .modal-dialog.modal-dialog-centered .modal-content,
  .modal-dialog.modal-dialog-scrollable .modal-content {
    border-radius:20px 20px 0 0 !important;
    border:none; max-height:85vh;
    animation:slideUpSheet .25s ease;
  }
  @keyframes slideUpSheet { from{transform:translateY(100%)} to{transform:translateY(0)} }
  /* 작은 모달도 바텀시트 */
  .modal-dialog.modal-sm { max-width:100%; }

  /* 모바일 필터 바: 수평 스크롤 */
  .mobile-filter-scroll {
    display:flex; align-items:center; gap:8px;
    flex-wrap:nowrap !important; /* 인라인 flex-wrap:wrap 오버라이드 */
    overflow-x:auto; padding:10px 0;
    scrollbar-width:none; -ms-overflow-style:none;
    -webkit-overflow-scrolling:touch;
  }
  .mobile-filter-scroll::-webkit-scrollbar { display:none; }
  .mobile-filter-scroll > * { flex-shrink:0; }
  .mobile-filter-scroll .date-range-box { min-width:180px; }
  .mobile-filter-scroll #f-sort { margin-left:0; }

  /* 모바일 카드 통계 가독성 */
  .hotel-stats { font-size:.78rem; gap:8px; }
  .hotel-desc  { font-size:.84rem; }

  /* 모바일 상세 페이지 하단 고정 CTA */
  .mobile-book-bar {
    position:fixed; bottom:0; left:0; right:0; z-index:9990;
    background:#fff; border-top:1px solid #e2e8f0;
    box-shadow:0 -4px 16px rgba(0,0,0,.12);
    padding:10px 16px; display:flex; align-items:center; gap:12px;
  }
  .mobile-book-bar .mobile-price {
    flex:1; min-width:0;
  }
  .mobile-book-bar .mobile-price-amount {
    font-size:1.1rem; font-weight:900; color:#166534; line-height:1.2;
  }
  .mobile-book-bar .mobile-price-night {
    font-size:.72rem; color:#64748b;
  }
  .mobile-book-bar .btn-book-mobile {
    flex-shrink:0; padding:12px 24px; border-radius:12px;
    font-weight:800; font-size:.95rem; color:#fff; border:none;
    white-space:nowrap;
  }
  body.has-mobile-book-bar { padding-bottom:72px; }

}

/* ── 도시 목록 fade 더보기 ── */
.city-fade-section {
  position:relative; margin-top:-40px; padding-top:10px;
  text-align:center; z-index:2;
}
.city-fade-section .city-fade-overlay {
  position:absolute; top:-50px; left:0; right:0; height:60px;
  background:linear-gradient(transparent, #fff);
  pointer-events:none;
}
.city-fade-btn {
  position:relative; z-index:3;
  background:#fff; border:1.5px solid #e2e8f0;
  border-radius:24px; padding:8px 24px;
  font-size:.85rem; font-weight:600; color:#3b82f6;
  cursor:pointer; transition:all .15s;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.city-fade-btn:hover { background:#3b82f6; color:#fff; border-color:#3b82f6; }
#city-grid-main { position:relative; }
#city-grid-main.expanded + .city-fade-section { display:none; }

/* ── 숙소 비교 ── */
.compare-table th, .compare-table td { vertical-align:top; text-align:center; font-size:.85rem; }
.compare-hotel-th { min-width:160px; }
.compare-img { width:100%; height:100px; object-fit:cover; border-radius:10px; margin-bottom:8px; }
.compare-name { font-weight:700; font-size:.9rem; color:#1e293b; text-decoration:none; display:block; }
.compare-name:hover { color:#3b82f6; }
.compare-label { font-weight:600; color:#64748b; text-align:left; white-space:nowrap; }
.compare-highlight { background:#f8fafc; }
.compare-highlight td { border-bottom:2px solid #e2e8f0; }

/* ── 비교 플로팅 바 ── */
.compare-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:9998;
  background:#1e293b; color:#fff; padding:10px 0;
  box-shadow:0 -4px 16px rgba(0,0,0,.2);
  transform:translateY(100%); transition:transform .3s ease;
}
.compare-bar.show { transform:translateY(0); }
.compare-bar-inner {
  display:flex; align-items:center; gap:10px;
  max-width:1200px; margin:0 auto; padding:0 16px;
}
.compare-items { display:flex; gap:8px; flex:1; overflow-x:auto; }
.compare-chip {
  display:flex; align-items:center; gap:6px;
  background:#334155; border-radius:8px; padding:4px 10px;
  font-size:.8rem; white-space:nowrap;
}
.compare-chip img { width:32px; height:24px; object-fit:cover; border-radius:4px; }
.compare-chip-x {
  background:none; border:none; color:#94a3b8; cursor:pointer;
  font-size:.9rem; padding:0 2px;
}
.compare-btn {
  background:#3b82f6; color:#fff; border:none; border-radius:8px;
  padding:8px 20px; font-weight:700; font-size:.85rem; cursor:pointer;
  white-space:nowrap;
}
.compare-btn:disabled { opacity:.4; cursor:default; }
.compare-reset-btn, .compare-close-btn {
  background:none; border:none; color:#94a3b8; cursor:pointer;
  font-size:1rem; padding:4px;
}
.compare-reset-btn:hover, .compare-close-btn:hover { color:#fff; }
.compare-toggle-btn {
  position:fixed; bottom:16px; right:70px; z-index:9997;
  width:44px; height:44px; border-radius:50%;
  background:#1e293b; color:#fff; border:none;
  font-size:1.2rem; cursor:pointer;
  box-shadow:0 2px 10px rgba(0,0,0,.3);
  display:flex; align-items:center; justify-content:center;
}

/* ── 검색 자동완성 ── */
.search-suggest {
  position:absolute; top:100%; left:0; right:0; z-index:1050;
  background:#fff; border-radius:0 0 12px 12px;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
  max-height:400px; overflow-y:auto;
}
.suggest-item {
  display:flex; align-items:center; gap:10px;
  padding:8px 12px; text-decoration:none; color:#1e293b;
  transition:background .1s;
}
.suggest-item:hover, .suggest-item.active { background:#f1f5f9; }
.suggest-item img {
  width:50px; height:36px; object-fit:cover; border-radius:6px; flex-shrink:0;
}
.suggest-item .si-info { flex:1; min-width:0; }
.suggest-item .si-name {
  font-size:.85rem; font-weight:600;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.suggest-item .si-loc { font-size:.7rem; color:#94a3b8; }

/* ── 최근 본 숙소 바 ── */
.recent-bar {
  position:fixed; bottom:0; left:0; right:0; z-index:9999;
  background:#fff; border-top:1px solid #e2e8f0;
  box-shadow:0 -4px 16px rgba(0,0,0,.12);
  padding:12px 0 10px;
}
body.has-recent-bar { padding-bottom:130px; }
.recent-title { font-weight:700; font-size:.85rem; color:#1e293b; }
.recent-close {
  background:none; border:none; font-size:1rem; color:#94a3b8;
  cursor:pointer; padding:0 4px;
}
.recent-scroll {
  display:flex; gap:10px; overflow-x:auto;
  scrollbar-width:none; -ms-overflow-style:none;
}
.recent-scroll::-webkit-scrollbar { display:none; }
.recent-item {
  flex:0 0 auto; width:130px; text-decoration:none; color:#1e293b;
}
.recent-item img {
  width:130px; height:80px; object-fit:cover; border-radius:8px;
  display:block;
}
.recent-item .ri-name {
  font-size:.75rem; font-weight:600; margin-top:4px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.recent-item .ri-city {
  font-size:.65rem; color:#94a3b8;
}

.recent-toggle-btn {
  position:fixed; bottom:16px; right:16px; z-index:999;
  width:44px; height:44px; border-radius:50%;
  background:#3b82f6; color:#fff; border:none;
  font-size:1.2rem; cursor:pointer;
  box-shadow:0 2px 10px rgba(59,130,246,.4);
  display:flex; align-items:center; justify-content:center;
}

/* ── 가격 필터 ── */
.price-filter-row { display:flex; gap:12px; align-items:flex-start; flex-wrap:wrap; }
.price-pills { display:flex; gap:6px; flex-wrap:wrap; }
.ppill {
  padding:5px 14px; border-radius:20px; border:1.5px solid #e2e8f0;
  background:#fff; color:#475569; font-size:.82rem; font-weight:500;
  cursor:pointer; transition:all .15s;
}
.ppill:hover { border-color:#3b82f6; color:#3b82f6; }
.ppill.active {
  background:#3b82f6; color:#fff; border-color:#3b82f6;
}

/* ── 가격 range slider ── */
.price-range-wrap { flex:1; min-width:200px; max-width:350px; }
.price-range-labels {
  display:flex; justify-content:space-between;
  font-size:.75rem; color:#3b82f6; font-weight:600; margin-bottom:2px;
}
.price-range-track { position:relative; height:30px; }
.price-range-track input[type=range] {
  position:absolute; top:0; left:0; width:100%;
  -webkit-appearance:none; appearance:none;
  background:transparent; pointer-events:none;
  height:30px; margin:0;
}
.price-range-track input[type=range]::-webkit-slider-thumb {
  -webkit-appearance:none; appearance:none;
  width:18px; height:18px; border-radius:50%;
  background:#3b82f6; border:2px solid #fff;
  box-shadow:0 1px 4px rgba(0,0,0,.2);
  cursor:pointer; pointer-events:auto;
  margin-top:-6px;
}
.price-range-track input[type=range]::-webkit-slider-runnable-track {
  height:6px; border-radius:3px; background:#e2e8f0;
}

/* ── 카드 이미지 캐러셀 ── */
.hotel-carousel { position:relative; overflow:hidden; }
.hotel-carousel .carousel-inner {
  position:relative; height:180px;
}
.hotel-detail-img .hotel-carousel .carousel-inner {
  height:350px;
}
.hotel-carousel .carousel-inner img {
  position:absolute; top:0; left:0; width:100%; height:100%;
  object-fit:cover; display:block; opacity:0;
  transition:opacity .3s ease;
}
.hotel-carousel .carousel-inner img.active {
  opacity:1;
}
.hotel-carousel .carousel-link {
  position:absolute; top:0; left:0; right:0; bottom:24px; z-index:1;
}
.carousel-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  background:rgba(0,0,0,.45); color:#fff; border:none;
  width:32px; height:32px; border-radius:50%;
  font-size:1.2rem; line-height:1; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .2s; z-index:2;
}
.hotel-carousel:hover .carousel-btn { opacity:1; }
@media (max-width: 768px) { .carousel-btn { opacity:.7; } }
.carousel-btn.prev { left:6px; }
.carousel-btn.next { right:6px; }
.carousel-dots {
  position:absolute; bottom:6px; left:50%; transform:translateX(-50%);
  display:flex; gap:4px;
}
.carousel-dots .dot {
  width:7px; height:7px; border-radius:50%;
  background:rgba(255,255,255,.5); cursor:pointer;
  /* 터치 영역 확장: 시각적 크기는 유지하되 클릭 가능 영역 확대 */
  padding:5px; background-clip:content-box;
}
.carousel-dots .dot.active { background:rgba(255,255,255,1); background-clip:content-box; }

/* 모바일 캐러셀 dot 터치 영역 확대 (글로벌 규칙 뒤에 배치하여 캐스케이드 보장) */
@media (max-width:768px) {
  .carousel-dots .dot {
    width:8px; height:8px;
    padding:6px; background-clip:content-box;
  }
  .carousel-dots .dot.active { background:rgba(255,255,255,1); background-clip:content-box; }
}

/* ===== Q&A Board (네이버 카페 스타일) ===== */
.icon-grid-2 { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }

/* 목록: 리스트 행 + 구분선 */
.qa-list { background:#fff; border-radius:16px; border:1.5px solid #e2e8f0; overflow:hidden; }
.qa-row { display:flex; align-items:center; padding:16px 20px;
  border-bottom:1px solid #f1f5f9; gap:12px; text-decoration:none; color:inherit; }
.qa-row:last-child { border-bottom:none; }
.qa-row:hover { background:#fafbfc; }
.qa-row .bullet { color:#1d4ed8; font-size:.6rem; flex-shrink:0; align-self:flex-start; margin-top:6px; }
.qa-row-body { flex:1; min-width:0; }
.qa-row-title { font-size:.95rem; font-weight:700; color:#1e293b;
  overflow:hidden; text-overflow:ellipsis;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.qa-row-meta { font-size:.75rem; color:#94a3b8; margin-top:5px;
  display:flex; gap:8px; align-items:center; flex-wrap:wrap; }

/* 우측 댓글 배지 (초록) */
.qa-comment-badge { flex-shrink:0; min-width:44px; text-align:center;
  background:#f0fdf4; border:1.5px solid #bbf7d0; border-radius:10px;
  padding:8px 6px; }
.qa-comment-badge .num { font-size:1rem; font-weight:800; color:#16a34a; display:block; line-height:1.2; }
.qa-comment-badge .lbl { font-size:.62rem; color:#4ade80; }

/* 필터 */
.qa-filter-bar { padding:12px 0; margin-bottom:4px; display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.qa-filter-bar select { border:1.5px solid #e2e8f0; border-radius:8px;
  padding:7px 12px; font-size:.83rem; background:#f8fafc; color:#1e293b; }
.qa-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.qa-header h2 { font-size:1.1rem; font-weight:800; color:#1e293b; margin:0; }

/* 상세 */
.qa-detail-box { background:#fff; border-radius:16px; border:1.5px solid #e2e8f0; padding:24px; margin-bottom:16px; }
.qa-detail-title { font-size:1.2rem; font-weight:800; color:#1e293b; line-height:1.4; margin-bottom:12px; }
.qa-detail-meta { font-size:.8rem; color:#94a3b8; display:flex; gap:10px; flex-wrap:wrap; align-items:center;
  padding-bottom:14px; border-bottom:1px solid #f1f5f9; }
.qa-content { white-space:pre-wrap; word-break:break-word;
  line-height:1.8; font-size:.92rem; color:#334155; padding:20px 0; min-height:80px; }
.qa-like-btn { display:inline-flex; align-items:center; justify-content:center;
  gap:6px; padding:10px 28px;
  border:1.5px solid #e2e8f0; border-radius:20px; background:#fff;
  font-size:.88rem; color:#64748b; cursor:pointer; transition:all .15s; }
.qa-like-btn:hover, .qa-like-btn.active { border-color:#ef4444; color:#ef4444; }
.qa-like-wrap { text-align:center; padding:12px 0; border-bottom:1px solid #f1f5f9; }

/* 댓글 섹션 */
.qa-comments-header { font-size:.95rem; font-weight:700; color:#1e293b;
  padding:14px 0 10px; }
.qa-comment-item { padding:14px 0; border-bottom:1px solid #f1f5f9; }
.qa-comment-item:last-child { border-bottom:none; }
.qa-comment-nick { font-size:.82rem; font-weight:700; color:#1e293b; }
.qa-comment-nick .author-badge { font-size:.68rem; color:#fff; background:#1d4ed8;
  padding:1px 5px; border-radius:4px; margin-left:4px; }
.qa-comment-text { font-size:.88rem; color:#334155; margin:4px 0; line-height:1.6; }
.qa-comment-date { font-size:.72rem; color:#94a3b8; }
.qa-comment-form { display:flex; gap:8px; padding:14px 0; align-items:flex-start; flex-wrap:wrap; }
.qa-comment-form input, .qa-comment-form textarea {
  border:1.5px solid #e2e8f0; border-radius:8px; padding:8px 12px;
  font-size:.85rem; background:#f8fafc; }
.qa-comment-form input { width:120px; flex-shrink:0; }
.qa-comment-form textarea { flex:1; min-width:0; resize:none; min-height:40px; }
.qa-comment-form button { padding:8px 18px; background:#1d4ed8; color:#fff;
  border:none; border-radius:8px; font-size:.85rem; font-weight:600; cursor:pointer; flex-shrink:0; }

/* 하단 바 */
.qa-bottom-bar { display:flex; justify-content:space-between; align-items:center;
  padding:14px 0; margin-top:8px; }
.qa-bottom-bar a { color:#64748b; text-decoration:none; font-size:.85rem; font-weight:600; }
.qa-bottom-bar a:hover { color:#1d4ed8; }
.qa-bottom-bar .stats { font-size:.8rem; color:#94a3b8; display:flex; gap:12px; }

/* 인라인 글쓰기 버튼 */
.qa-write-inline-btn {
  display:inline-flex; align-items:center; gap:5px; flex-shrink:0;
  padding:8px 16px; border-radius:20px;
  background:#1d4ed8; color:#fff; font-size:.83rem; font-weight:700;
  text-decoration:none; transition:all .2s; white-space:nowrap;
  box-shadow:0 2px 8px rgba(29,78,216,.25);
}
.qa-write-inline-btn:hover { background:#1e40af; color:#fff; box-shadow:0 4px 12px rgba(29,78,216,.35); transform:translateY(-1px); }

/* 글쓰기 폼 */
.qa-write-box { background:#fff; border-radius:16px; border:1.5px solid #e2e8f0; padding:24px; }
.qa-write-box .form-group { margin-bottom:16px; }
.qa-write-box label { display:block; font-size:.85rem; font-weight:700; color:#1e293b; margin-bottom:6px; }
.qa-write-box label .required { color:#ef4444; margin-left:2px; }
.qa-write-box input, .qa-write-box select, .qa-write-box textarea {
  width:100%; border:1.5px solid #e2e8f0; border-radius:10px; padding:10px 14px;
  font-size:.88rem; background:#f8fafc; color:#1e293b; box-sizing:border-box; }
.qa-write-box textarea { min-height:200px; resize:vertical; line-height:1.7; }
.qa-write-box input:focus, .qa-write-box select:focus, .qa-write-box textarea:focus {
  outline:none; border-color:#1d4ed8; background:#fff; }
.qa-write-box .submit-btn { width:100%; padding:12px; background:#1d4ed8; color:#fff;
  border:none; border-radius:10px; font-size:.95rem; font-weight:700; cursor:pointer; }
.qa-write-box .submit-btn:hover { background:#1e40af; }
.qa-write-box .error-msg { background:#fef2f2; border:1px solid #fecaca; color:#dc2626;
  padding:10px 14px; border-radius:8px; font-size:.85rem; margin-bottom:16px; }

/* 페이지네이션 */
.qa-pagination { display:flex; justify-content:center; gap:4px; padding:16px 0; }
.qa-pagination a, .qa-pagination span { display:inline-flex; align-items:center; justify-content:center;
  min-width:34px; height:34px; border-radius:8px; font-size:.85rem; font-weight:600;
  text-decoration:none; color:#64748b; border:1px solid #e2e8f0; }
.qa-pagination a:hover { background:#f1f5f9; color:#1d4ed8; }
.qa-pagination .active { background:#1d4ed8; color:#fff; border-color:#1d4ed8; }
.qa-pagination .disabled { color:#cbd5e1; pointer-events:none; }

/* 빈 상태 */
.qa-empty { text-align:center; padding:48px 20px; color:#94a3b8; }
.qa-empty .icon { font-size:2.5rem; margin-bottom:8px; }
.qa-empty p { font-size:.9rem; }
