/**
 * atJeju — 카카오맵 지도
 */

.page-body--map {
  background: var(--color-bg);
}

.app-main--map {
  padding: 0;
  padding-bottom: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.map-page {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: calc(
    100dvh - var(--header-h) - var(--tabbar-h) - var(--safe-top) - var(--safe-bottom)
  );
  min-height: calc(
    100vh - var(--header-h) - var(--tabbar-h) - var(--safe-top) - var(--safe-bottom)
  );
}

.map-toolbar {
  position: absolute;
  top: var(--space-3);
  left: calc(var(--space-3) + var(--safe-left));
  right: calc(var(--space-3) + var(--safe-right));
  z-index: 10;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-2);
  pointer-events: none;
}

.map-toolbar__left,
.map-toolbar__right {
  display: flex;
  gap: var(--space-2);
  pointer-events: auto;
}

.map-toolbar__left {
  flex: 1;
  min-width: 0;
}

.map-toolbar__right {
  flex-shrink: 0;
}

.map-tool-btn {
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 40px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  box-shadow: var(--shadow-sm);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text);
  cursor: pointer;
}

.map-tool-btn--locate {
  width: 44px;
  height: 44px;
  padding: 0;
  justify-content: center;
  border-radius: 50%;
  font-size: 1.1rem;
}

/* Kakao Map SDK 마운트 영역 */
.map-canvas-wrap {
  position: relative;
  flex: 1;
  min-height: 200px;
}

.map-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background: #dbeafe;
}

.map-loading {
  position: absolute;
  inset: 0;
  z-index: 8;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  background: rgba(255, 255, 255, 0.72);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-muted);
}

.map-loading.hidden {
  display: none !important;
}

.map-loading__spinner {
  width: 28px;
  height: 28px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: map-spin 0.8s linear infinite;
}

@keyframes map-spin {
  to {
    transform: rotate(360deg);
  }
}

.map-focus-panel {
  position: absolute;
  top: calc(var(--space-3) + 52px);
  left: calc(var(--space-3) + var(--safe-left));
  right: calc(var(--space-3) + var(--safe-right));
  z-index: 12;
  pointer-events: none;
}

.map-focus-panel.hidden {
  display: none !important;
}

.map-focus-panel__inner {
  pointer-events: auto;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-xl);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(13, 148, 136, 0.35);
  box-shadow: var(--shadow-sm);
}

.map-focus-panel__eyebrow {
  margin: 0 0 var(--space-1);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-primary);
}

.map-focus-panel__title {
  margin: 0;
  font-size: var(--font-size-base);
  line-height: 1.35;
}

.map-focus-panel__meta {
  margin: var(--space-1) 0 0;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}

.map-focus-panel__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.map-focus-panel__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 var(--space-4);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-decoration: none;
}

.map-focus-panel__exit {
  min-height: 36px;
  padding: 0 var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  cursor: pointer;
  font-family: inherit;
}

.map-page--focus .map-toolbar__left {
  opacity: 0.45;
  pointer-events: none;
}

.map-page--focus .map-recommend-block {
  display: none;
}

.map-page--focus #map-filter-btn {
  opacity: 0.45;
  pointer-events: none;
}

.map-status-banner {
  position: absolute;
  top: calc(var(--space-3) + 52px);
  left: calc(var(--space-3) + var(--safe-left));
  right: calc(var(--space-3) + var(--safe-right));
  z-index: 11;
  padding: var(--space-2) var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: #92400e;
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}

.map-status-banner--error {
  color: #991b1b;
  background: #fef2f2;
  border-color: #fecaca;
}

.map-status-banner.hidden {
  display: none !important;
}

.map-status-banner--focus-offset {
  top: calc(var(--space-3) + 52px + 108px);
}

.map-filter-panel {
  position: absolute;
  top: calc(var(--space-3) + 52px);
  left: calc(var(--space-3) + var(--safe-left));
  right: calc(var(--space-3) + var(--safe-right));
  z-index: 12;
  padding: var(--space-3);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  max-height: 40vh;
  overflow-y: auto;
}

.map-filter-panel.hidden {
  display: none !important;
}

.map-chip-group {
  display: flex;
  gap: var(--space-2);
  flex-wrap: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.map-chip-group--wrap {
  flex-wrap: wrap;
  overflow: visible;
}

.map-chip {
  flex-shrink: 0;
  min-height: 34px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-text);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.map-chip.is-active {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
}

.map-chip--filter:not(.is-active) {
  opacity: 0.72;
}

/* Kakao InfoWindow 커스텀 */
.map-infowindow {
  width: 220px;
  padding: var(--space-2) var(--space-1);
  font-size: var(--font-size-sm);
  line-height: 1.45;
}

.map-infowindow__title {
  display: block;
  margin: 0 0 4px;
  font-size: var(--font-size-base);
}

.map-infowindow__weather {
  color: #0369a1;
  font-weight: 500;
}

.map-infowindow__weather--loading {
  color: var(--color-text-muted);
  font-weight: 400;
}

.map-infowindow__meta,
.map-infowindow__addr,
.map-infowindow__summary {
  margin: 0 0 4px;
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
}

.map-infowindow__cta {
  display: inline-flex;
  margin-top: var(--space-2);
  margin-right: var(--space-2);
  padding: 6px 12px;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: #fff;
  font-weight: 700;
  text-decoration: none;
  border: none;
  cursor: pointer;
  font-size: inherit;
  font-family: inherit;
}

.map-infowindow__cta--trail {
  background: #0f766e;
}

/* legacy placeholder (미사용) */
.map-canvas__island,
.map-canvas__label,
.map-canvas__status,
.map-markers,
.map-pin {
  display: none !important;
}

/* 하단 시트 */
.map-sheet {
  flex-shrink: 0;
  background: var(--color-surface);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.08);
  max-height: 42%;
  display: flex;
  flex-direction: column;
  transition: max-height 0.25s ease;
}

.map-sheet--collapsed {
  max-height: 52px;
}

.map-sheet--collapsed .map-sheet__body {
  display: none;
}

.map-sheet__handle {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  padding: var(--space-2) var(--space-4) var(--space-3);
  border: none;
  background: transparent;
  cursor: pointer;
}

.map-sheet__grab {
  width: 40px;
  height: 4px;
  border-radius: var(--radius-full);
  background: var(--color-border);
  margin-bottom: var(--space-2);
}

.map-sheet__title {
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--color-text);
}

.map-sheet__count {
  font-weight: 600;
  color: var(--color-text-muted);
}

.map-sheet__body {
  overflow-y: auto;
  padding: 0 var(--space-4) var(--space-4);
  padding-bottom: calc(var(--space-4) + var(--safe-bottom));
  -webkit-overflow-scrolling: touch;
}

.map-selected {
  margin-bottom: var(--space-4);
}

.map-selected.hidden {
  display: none !important;
}

.map-selected-card {
  padding: var(--space-4);
  background: var(--color-primary-light);
  border: 1px solid rgba(13, 148, 136, 0.3);
  border-radius: var(--radius-md);
}

.map-selected-card__eyebrow {
  margin: 0 0 var(--space-1);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-primary-dark);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.map-selected-card__title {
  margin: 0 0 var(--space-1);
  font-size: var(--font-size-lg);
  font-weight: 800;
}

.map-selected-card__category,
.map-selected-card__area {
  margin: 0 0 var(--space-1);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.map-status {
  margin: 0;
  padding: var(--space-4);
  text-align: center;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.map-selected-card__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: var(--space-3);
  min-height: 40px;
  padding: 0 var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: #fff;
  background: var(--color-primary);
  border-radius: var(--radius-md);
}

.map-recommend-block {
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
}

.map-recommend-block__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.map-recommend-block__title {
  margin: 0;
  font-size: var(--font-size-sm);
  font-weight: 700;
  color: var(--color-primary);
}

.map-recommend-block__meta {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted, #64748b);
  white-space: nowrap;
}

.map-recommend-block__summary {
  margin: 0 0 var(--space-3);
  font-size: var(--font-size-xs);
  line-height: 1.45;
  color: var(--color-text-muted, #64748b);
}

.map-recommend-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.map-recommend-list .map-nearby-card {
  padding: var(--space-2) var(--space-3);
}

.map-nearby-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.map-nearby-card {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
}

.map-nearby-card__media {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--color-primary-light), #e5e7eb);
}

.map-nearby-card__body {
  flex: 1;
  min-width: 0;
}

.map-nearby-card__badge {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-primary-dark);
  margin-bottom: 2px;
}

.map-nearby-card__title {
  margin: 0 0 2px;
  font-size: var(--font-size-base);
  font-weight: 700;
}

.map-nearby-card__meta {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

/* 데스크탑 사이드바 — 거리순 컴팩트 리스트 */
.map-sidebar-list {
  display: flex;
  flex-direction: column;
}

.map-sidebar-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
  text-decoration: none;
  color: inherit;
}

.map-sidebar-row:last-child {
  border-bottom: none;
}

.map-sidebar-row:hover {
  background: var(--color-bg);
}

.map-sidebar-row__main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.map-sidebar-row__title {
  font-size: var(--font-size-sm);
  font-weight: 700;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.map-sidebar-row__badge {
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: var(--color-text-muted);
}

.map-sidebar-row__dist {
  flex-shrink: 0;
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-primary-dark);
  white-space: nowrap;
}

.map-sidebar-more {
  margin: var(--space-3) 0 0;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-align: center;
}
