/* ===== partner-detail.css ===== */
/* 레미오 제휴매장 상세 페이지 */

:root {
  --pink: #FF6B9D;
  --cream: #FFF4E6;
  --red: #FF4757;
  --dark: #2C2C2C;
  --bg: #FFFBF7;
  --gray: #888;
  --light-gray: #F5F5F5;
  --border: #EEE;
  --yellow: #FFD700;
  --shadow: 0 2px 12px rgba(0,0,0,.08);
}

* { margin:0; padding:0; box-sizing:border-box; }

body {
  background: var(--bg);
  color: var(--dark);
  font-family: 'Jua','Do Hyeon','Nanum Gothic',sans-serif;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  line-height: 1.6;
}

img { max-width:100%; height:auto; display:block; }
a { color: inherit; text-decoration: none; }

/* ===== 전체 컨테이너 ===== */
.partner-detail {
  max-width: 640px;
  margin: 0 auto;
  padding-bottom: 60px;
}

/* ===== 상단 네비게이션 ===== */
.partner-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  background: white;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
}
.nav-back, .nav-home {
  font-size: 14px;
  color: var(--dark);
  padding: 6px 12px;
  border-radius: 20px;
  transition: background .2s;
}
.nav-back:hover, .nav-home:hover { background: var(--cream); }

/* ===== 히어로 이미지 ===== */
.partner-hero {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--light-gray);
}
.partner-hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ===== 매장 정보 헤더 ===== */
.partner-header {
  padding: 24px 20px 16px;
  background: white;
}
.partner-emotional {
  font-family: 'Gamja Flower', cursive;
  font-size: 18px;
  color: var(--pink);
  margin-bottom: 8px;
  letter-spacing: .3px;
}
.partner-title {
  font-family: 'Jua', sans-serif;
  font-size: 26px;
  color: var(--dark);
  margin-bottom: 12px;
  line-height: 1.3;
}
.partner-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 14px;
  color: var(--gray);
}
.partner-address, .partner-category {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ===== 레미오 혜택 카드 ===== */
.partner-benefit-card {
  margin: 16px 20px;
  padding: 20px;
  background: linear-gradient(135deg, #FFF0F5, #FFF8E7);
  border: 2px solid var(--pink);
  border-radius: 16px;
  text-align: center;
}
.benefit-header {
  font-family: 'Jua', sans-serif;
  font-size: 16px;
  color: var(--pink);
  margin-bottom: 12px;
  letter-spacing: .5px;
}
.benefit-content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 10px;
}
.benefit-icon { font-size: 28px; }
.benefit-text {
  font-family: 'Gamja Flower', cursive;
  font-size: 20px;
  color: var(--dark);
  font-weight: 700;
}
.benefit-note {
  font-size: 12px;
  color: var(--gray);
  margin-top: 8px;
}

/* ===== 매장 소개 ===== */
.partner-description {
  padding: 24px 20px;
  background: white;
  margin-top: 8px;
}
.partner-description h2 {
  font-family: 'Jua', sans-serif;
  font-size: 18px;
  margin-bottom: 14px;
  color: var(--dark);
}
.partner-description p {
  font-family: 'Jua', sans-serif;
  font-size: 15px;
  color: #555;
  line-height: 1.8;
  word-break: keep-all;
}

/* ===== 사진 갤러리 ===== */
.partner-gallery, .partner-menu-section {
  padding: 24px 20px;
  background: white;
  margin-top: 8px;
}
.partner-gallery h2, .partner-menu-section h2 {
  font-family: 'Jua', sans-serif;
  font-size: 18px;
  margin-bottom: 14px;
  color: var(--dark);
}
.gallery-grid, .menu-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.partner-gallery-item {
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 1;
  background: var(--light-gray);
}
.partner-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .3s;
}
.partner-gallery-item img:hover { transform: scale(1.05); }

/* ===== CTA 버튼 ===== */
.partner-cta {
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.partner-cta-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px;
  background: #03C75A;
  color: white;
  border-radius: 12px;
  font-family: 'Jua', sans-serif;
  font-size: 16px;
  transition: opacity .2s;
}
.partner-cta-primary:hover { opacity: .9; }
.partner-cta-secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px;
  background: var(--pink);
  color: white;
  border-radius: 12px;
  font-family: 'Jua', sans-serif;
  font-size: 15px;
  transition: opacity .2s;
}
.partner-cta-secondary:hover { opacity: .9; }

/* ===== 다른 매장 추천 ===== */
.partner-related {
  padding: 24px 20px;
  background: white;
  margin-top: 8px;
}
.partner-related h2 {
  font-family: 'Jua', sans-serif;
  font-size: 18px;
  margin-bottom: 16px;
  color: var(--dark);
}
.related-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}
.partner-related-card {
  display: block;
  border-radius: 12px;
  overflow: hidden;
  background: var(--light-gray);
  transition: transform .2s;
}
.partner-related-card:hover { transform: translateY(-2px); }
.related-card-img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}
.related-card-info {
  padding: 8px 10px 12px;
}
.related-card-name {
  font-family: 'Jua', sans-serif;
  font-size: 13px;
  color: var(--dark);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.related-card-ep {
  font-size: 11px;
  color: var(--gray);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ===== 푸터 ===== */
.partner-footer {
  padding: 30px 20px;
  text-align: center;
  color: var(--gray);
  font-size: 13px;
  margin-top: 8px;
  background: white;
}
.partner-footer nav {
  margin-top: 10px;
  display: flex;
  justify-content: center;
  gap: 20px;
}
.partner-footer nav a {
  color: var(--pink);
  font-size: 14px;
}

/* ===== 반응형: 태블릿 ===== */
@media (min-width:768px) {
  .partner-detail { max-width:720px; }
  .partner-title { font-size:30px; }
  .gallery-grid, .menu-grid { grid-template-columns: 1fr 1fr 1fr; }
}

/* ===== 반응형: 데스크톱 ===== */
/* ===== 라이트박스 (이미지 확대) ===== */
.lightbox-overlay {
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.92); align-items:center; justify-content:center;
  cursor:zoom-out; -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
}
.lightbox-overlay.open { display:flex; }
.lightbox-overlay img {
  max-width:92vw; max-height:88vh; object-fit:contain;
  border-radius:8px; box-shadow:0 8px 40px rgba(0,0,0,.5);
  animation: lbFadeIn .2s ease;
}
.lightbox-close {
  position:absolute; top:16px; right:20px;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.15); border:none;
  color:#fff; font-size:20px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s;
}
.lightbox-close:hover { background:rgba(255,255,255,.3); }
@keyframes lbFadeIn { from{opacity:0;transform:scale(.95)} to{opacity:1;transform:scale(1)} }

/* 갤러리 이미지 커서 */
.partner-gallery-item img { cursor:zoom-in; transition:transform .2s; }
.partner-gallery-item img:hover { transform:scale(1.03); }

@media (min-width:1024px) {
  .partner-detail { max-width:800px; }
  .partner-hero { aspect-ratio:2/1; }
  .partner-nav { padding:14px 30px; }
  .partner-header { padding:30px; }
  .partner-benefit-card { margin:20px 30px; }
  .partner-description, .partner-gallery, .partner-menu-section, .partner-related { padding:30px; }
  .partner-cta { padding:24px 30px; }
}
