/* ==========================================================
   VIP SHOP CARD (독립 스코프)
   적용 범위: .vip-slide 내부에서만 동작
========================================================== */

/* ---------------- 카드 랩 ---------------- */
.vip-slide .premium-vip-card{
  width:380px;
  margin:20px;
  display:inline-block;
  font-family:'Pretendard', sans-serif;
  vertical-align:top;
  text-align:left;
}

.vip-slide .card-inner{
  background:#fff;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 15px 35px rgba(0,0,0,0.07);
  border:1px solid rgba(0,0,0,0.03);
  transition:transform 0.3s;
}

.vip-slide .premium-vip-card:hover .card-inner{
  transform:translateY(-10px);
}

/* ---------------- 이미지 영역 ---------------- */
.vip-slide .image-area{
  position:relative;
  height:240px;
  display:block;
  overflow:hidden;
}

.vip-slide .card-img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* (shop_card.php에 image-overlay가 있으니, CSS도 같이 포함) */
.vip-slide .image-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.28), rgba(0,0,0,0) 55%);
  opacity:0.9;
  pointer-events:none;
}

/* ---------------- 배지 ---------------- */
.vip-slide .badge-premium{
  position:absolute;
  top:18px;
  left:18px;
  background:linear-gradient(135deg, #D4AF37, #F9E498);
  color:#4a3b00;
  padding:6px 14px;
  border-radius:12px;
  font-size:11px;
  font-weight:900;
  z-index:10;
  display:flex;
  align-items:center;
  gap:6px;
}

.vip-slide .badge-status{
  position:absolute;
  bottom:18px;
  left:18px;
  z-index:10;
  background:rgba(255,255,255,0.95);
  padding:6px 14px;
  border-radius:30px;
  font-size:12px;
  font-weight:800;
  display:flex;
  align-items:center;
  gap:7px;
}

.vip-slide .badge-status.is-open{ color:#00b894; }
.vip-slide .badge-status.is-closed{ color:#636e72; }

.vip-slide .pulse-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:currentColor;
  position:relative;
}

.vip-slide .is-open .pulse-dot::after{
  content:'';
  position:absolute;
  inset:0;
  border-radius:50%;
  background:currentColor;
  animation:vipStatusPulse 1.5s infinite;
}

@keyframes vipStatusPulse{
  0%{ transform:scale(1); opacity:0.8; }
  100%{ transform:scale(2.5); opacity:0; }
}

.vip-slide .badge-discount{
  position:absolute;
  top:18px;
  right:18px;
  background:#ff3b30;
  color:#fff;
  padding:6px 12px;
  border-radius:12px;
  font-size:12px;
  font-weight:900;
  z-index:10;
}

/* ---------------- 정보 영역 ---------------- */
.vip-slide .info-area{
  padding:22px;
}

.vip-slide .info-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px;
}

.vip-slide .shop-cat{
  font-size:11px;
  color:#6c5ce7;
  font-weight:800;
  letter-spacing:0.2px;
}

.vip-slide .shop-rating{
  color:#fdcb6e;
  font-size:14px;
  font-weight:800;
  display:flex;
  align-items:center;
  gap:6px;
}

.vip-slide .shop-name{
  margin:0 0 10px;
  font-size:22px;
  font-weight:900;
  color:#2d3436;
  line-height:1.15;
}

.vip-slide .shop-name a{
  color:inherit;
  text-decoration:none;
}

.vip-slide .shop-addr{
  font-size:14px;
  color:#636e72;
  margin-bottom:20px;
  display:flex;
  align-items:center;
  gap:8px;
}

/* ---------------- 가격 / 버튼 ---------------- */
.vip-slide .shop-bottom{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  padding-top:18px;
  border-top:1px solid #f1f2f6;
}

.vip-slide .price-box del{
  display:block;
  font-size:13px;
  color:#b2bec3;
  line-height:1.1;
  margin-bottom:4px;
}

.vip-slide .final-price{
  font-size:26px;
  font-weight:900;
  color:#2d3436;
  line-height:1;
}

.vip-slide .final-price .unit{
  font-size:16px;
  margin-right:4px;
  vertical-align:baseline;
}

.vip-slide .quick-btns{
  display:flex;
  gap:10px;
}

.vip-slide .quick-btns button{
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid #f1f2f6;
  background:#fff;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .15s, box-shadow .15s, border-color .15s;
}

.vip-slide .quick-btns button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 16px rgba(0,0,0,0.08);
  border-color:rgba(0,0,0,0.08);
}

/* ---------------- 태그 ---------------- */
.vip-slide .tag-list{
  margin-top:15px;
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}

.vip-slide .tag-node{
  font-size:12px;
  background:#f1f2f6;
  color:#636e72;
  padding:4px 10px;
  border-radius:8px;
  white-space:nowrap;
}

/* ==========================================================
   모바일
========================================================== */
@media (max-width:480px){
  .vip-slide .premium-vip-card{
    width:100%;
    margin:10px 0;
    padding:0 10px;
    box-sizing:border-box;
  }

  .vip-slide .card-inner{ border-radius:20px; }
  .vip-slide .image-area{ height:180px; }
  .vip-slide .info-area{ padding:15px; }

  .vip-slide .shop-name{
    font-size:19px;
    margin:0 0 6px;
  }

  .vip-slide .shop-addr{
    font-size:13px;
    margin-bottom:15px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .vip-slide .shop-bottom{ padding-top:12px; }
  .vip-slide .final-price{ font-size:22px; }

  .vip-slide .quick-btns button{
    width:36px;
    height:36px;
  }

  .vip-slide .badge-premium{
    top:12px;
    left:12px;
    padding:4px 10px;
    font-size:10px;
  }

  .vip-slide .badge-status{
    bottom:12px;
    left:12px;
    padding:4px 10px;
    font-size:11px;
  }

  .vip-slide .badge-discount{
    top:12px;
    right:12px;
    padding:4px 8px;
    font-size:11px;
  }

  .vip-slide .tag-list{
    margin-top:10px;
    gap:4px;
  }

  .vip-slide .tag-node{
    font-size:11px;
    padding:3px 8px;
  }
}
