/* ===== 샵 전용 카드 ===== */

/* 슬라이더 카드 */
.slider-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  overflow: hidden;
  width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.slider-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 6px 16px rgba(0,0,0,0.15);
}
.slider-card .shop-image { position: relative; }
.slider-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  border-bottom: 1px solid #eee;
}

/* 배지 */
.shop-badges {
  position: absolute;
  top: 10px;
  left: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  z-index: 5;
}
.shop-badge {
  color: #fff;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 4px;
  font-weight: 600;
}
.shop-badge.추천 { background: #ff5b77; }
.shop-badge.신규 { background: #4cafef; }
.shop-badge.할인 { background: #ff9800; }
.shop-badge.인기 { background: #e91e63; }
.shop-badge.프리미엄 { background: #9c27b0; }
.shop-badge.베스트 { background: #3f51b5; }
.shop-badge.예약필수 { background: #009688; }
.shop-badge.한정특가 { background: #ff5722; }
.shop-badge.커플추천 { background: #795548; }

/* 영업 상태 */
.slider-card .shop-status {
  position: absolute;
  bottom: 10px;
  right: 10px;
  font-size: 13px;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 6px;
  color: #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}
.slider-card .shop-status.open { background: #4caf50; }
.slider-card .shop-status.closed { background: #f44336; }

/* 카드 내용 */
.slider-card .shop-info { padding: 15px; flex: 1; }
.slider-card .shop-info h2 {
  font-size: 18px;
  font-weight: 700;
  margin: 0 0 8px;
  color: #222;
}
.slider-card .shop-info p {
  font-size: 14px;
  margin: 4px 0;
  color: #555;
  line-height: 1.4;
}
.slider-card .shop-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  font-size: 13px;
  gap: 10px;
  margin-top: 8px;
}
.slider-card .shop-rating { color: #ff9800; font-weight: 600; }

/* 버튼 */
.slider-card .shop-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 12px;
}
.slider-card .shop-actions button,
.slider-card .shop-actions a {
  background: #ff5b77;
  border: none;
  padding: 7px 14px;
  border-radius: 6px;
  color: #fff;
  font-size: 13px;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.2s;
}
.slider-card .shop-actions button:hover,
.slider-card .shop-actions a:hover {
  background: #e14b66;
}

/* 지도 밑 리스트 */
.map-list { display: flex; flex-direction: column; gap: 12px; }
.map-card {
  display: flex; align-items: center; padding: 12px;
  background: #fff; border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}
.map-card img {
  width: 80px; height: 80px; object-fit: cover;
  border-radius: 8px; margin-right: 15px;
}
.map-info { flex: 1; }
.map-info h4 { font-size: 16px; font-weight: 600; margin: 0 0 4px; }
.map-meta { display: flex; align-items: center; gap: 8px; font-size: 13px; color: #555; }
.map-meta-bottom { display: flex; align-items: center; gap: 15px; margin-top: 5px; }
.map-card .copy-btn {
  font-size: 11px; padding: 2px 6px; margin-left: 6px;
  border: 1px solid #ff5b77; background: #fff;
  color: #ff5b77; border-radius: 4px; cursor: pointer;
}
.map-card .copy-btn:hover { background: #ff5b77; color: #fff; }
.map-card.active { border: 2px solid #ff5b77; }
.map-card.hidden { display: none; }

/* 리스트 페이지 */
.shop-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 20px;
}
.shop-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
}
.shop-card:hover { transform: translateY(-6px); box-shadow: 0 6px 16px rgba(0,0,0,0.12); }
.shop-card img { width: 100%; height: 180px; object-fit: cover; display: block; }
