/* ============================================
   PAGE-FNB.CSS — F&B 메뉴 페이지 전용
   ============================================ */

/* ── 카테고리 탑 네비 (sticky) ─────────────────────────── */

.fnb-topnav {
  position: sticky;
  top: var(--gnb-height);
  z-index: 30;
  background: var(--color-white);
  border-bottom: 1px solid var(--color-gray-5);
  box-shadow: 0 4px 16px rgba(0,0,0,.04);
}

.fnb-topnav__inner {
  display: flex;
  align-items: center;
  padding: 0 var(--container-pad);
}

.fnb-topnav__list {
  display: flex;
  gap: 0;
  flex: 1;
  overflow-x: auto;
  scrollbar-width: none;
}
.fnb-topnav__list::-webkit-scrollbar { display: none; }

.fnb-topnav__link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: 1rem 1.25rem;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-2);
  white-space: nowrap;
  border-bottom: 3px solid transparent;
  transition: color var(--duration-fast), border-color var(--duration-fast);
}
.fnb-topnav__link:hover { color: var(--color-dark); }
.fnb-topnav__link.is-active {
  color: var(--color-bg-brand);
  border-bottom-color: var(--color-bg-brand);
}
.fnb-topnav__link em {
  font-style: normal;
  font-size: var(--text-xs);
  color: var(--color-gray-3);
  font-weight: var(--fw-bold);
}

.fnb-topnav__progress {
  height: 2px;
  width: 100%;
  background: var(--color-gray-5);
  position: relative;
}
.fnb-topnav__progress-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0%;
  background: var(--color-bg-brand);
  transition: width 0.15s ease-out;
}

/* ── FNB 콘텐츠 컨테이너 ──────────────────────────────── */

.fnb-content {
  padding: 3rem var(--container-pad);
  display: flex;
  flex-direction: column;
  gap: 5rem;
}

.fnb-section {
  scroll-margin-top: calc(var(--gnb-height) + 90px);
}

/* ── 섹션별 히어로 배너 ──────────────────────────────── */

/* ── 카테고리 배너 — 배경 박스 제거 + 가운데 정렬 (2026-06-04) ──
   기존: 어두운 그라데이션/이미지 박스 + 좌측 정렬 흰 텍스트.
   변경: 박스 제거, 밝은 페이지 배경 위 가운데 정렬 다크 텍스트. */
.fnb-hero-banner {
  position: relative;
  padding: clamp(1.5rem, 4vw, 2.5rem) 0 clamp(1rem, 2.5vw, 1.5rem);
  margin-bottom: 2rem;
  background: none;
  color: var(--color-dark);
  text-align: center;
}

/* 카테고리별 배경 박스 제거 */
.fnb-hero-banner--western,
.fnb-hero-banner--munches,
.fnb-hero-banner--meals { background: none; }

.fnb-hero-banner__text {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.fnb-hero-banner__tag {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--fw-bold);
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .35rem .85rem;
  border-radius: var(--radius-full);
  background: var(--color-green);
  color: var(--color-white);
  margin-bottom: .85rem;
}

.fnb-hero-banner__title-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .35rem;
  margin-bottom: .85rem;
}
.fnb-hero-banner__sub {
  font-size: var(--text-sm);
  color: var(--color-gray-2);
  font-weight: var(--fw-medium);
}
.fnb-hero-banner__title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  font-weight: var(--fw-extrabold);
  letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--color-dark);
}

.fnb-hero-banner__meta {
  font-size: var(--text-sm);
  color: var(--color-gray-2);
  letter-spacing: -.01em;
}
.fnb-hero-banner__count {
  display: inline-block;
  margin-left: .5rem;
  padding: .15rem .55rem;
  background: var(--color-green);
  border-radius: var(--radius-full);
  font-weight: var(--fw-bold);
  color: var(--color-white);
  font-size: var(--text-xs);
}

/* ── 메뉴 이미지 그리드 ──────────────────────────────── */

.fnb-imgrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  /* 그리드 행 크기 고정 — 카드가 세로로 늘어나지 않도록 */
  align-items: start;
}
.fnb-imgrid--3col { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 899px) {
  .fnb-imgrid,
  .fnb-imgrid--3col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 479px) {
  .fnb-imgrid,
  .fnb-imgrid--3col { grid-template-columns: 1fr; }
}

.fnb-meals-pair {
  /* meals-pair 가 2개 row 를 차지하도록 명시 */
  grid-row: span 2;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.fnb-imgcard {
  background: var(--color-white);
  border: 1px solid var(--color-gray-5);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: transform var(--duration-normal), box-shadow var(--duration-normal);
  display: flex;
  flex-direction: column;
}
.fnb-imgcard:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.fnb-imgcard__img {
  /* 모든 카드 동일 비율 — 이미지 높이 통일 */
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--color-gray-6);
}
.fnb-imgcard__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow);
}
.fnb-imgcard:hover .fnb-imgcard__img img {
  transform: scale(1.05);
}

.fnb-meals-pair .fnb-imgcard__img { aspect-ratio: 4 / 3; }

.fnb-imgcard__name {
  padding: .85rem 1rem;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  letter-spacing: -.01em;
  text-align: center;
}

/* ── 추가 메뉴 태그 리스트 ───────────────────────────── */

.fnb-tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px dashed var(--color-gray-5);
}
.fnb-tag-list__item {
  padding: .45rem 1rem;
  background: var(--color-white);
  border: 1px solid var(--color-gray-5);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--color-dark-2);
  letter-spacing: -.01em;
}

/* ── 전체 메뉴 (All) — heybob 스타일 카테고리 그리드 ───────── */

.fnb-section__header {
  text-align: center;
  margin-bottom: 3rem;
  padding: 0 1rem;
}
.fnb-section__en {
  display: inline-block;
  font-size: var(--text-sm);
  font-weight: var(--fw-bold);
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--color-bg-brand);
  margin-bottom: .75rem;
}
.fnb-section__title-row {
  margin-bottom: .75rem;
}
.fnb-section__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: var(--fw-extrabold);
  letter-spacing: -.02em;
  color: var(--color-dark);
  line-height: 1.2;
}
.fnb-section__tag {
  display: inline-block;
  font-size: var(--text-sm);
  color: var(--color-gray-2);
  letter-spacing: -.01em;
}

/* 3등분 (2026-06-01): 식사 및 분식류 / 안주류 / (피자 및 웨스턴 + 음료 및 디저트 세로 stack) */
.fnb-all__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  align-items: start;
  gap: 2.5rem 3rem;
  max-width: 1200px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
  background: var(--color-white);
  border: 1px solid var(--color-gray-5);
  border-radius: var(--radius-xl);
}
/* 4 카테고리 (분식&밥 | 안주 | 전&피자 | 카페) — 태블릿 2열, 모바일 1열 */
@media (max-width: 1023px) {
  .fnb-all__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .fnb-all__grid {
    grid-template-columns: 1fr;
    gap: 2.25rem;
    padding: 2rem 1.25rem;
  }
}

/* col3 — 피자 및 웨스턴 위, 음료 및 디저트 아래 세로 배치 */
.fnb-all__col {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.fnb-all__category {
  display: flex;
  flex-direction: column;
}

.fnb-all__category h3 {
  font-size: var(--text-lg);
  font-weight: var(--fw-extrabold);
  color: var(--color-dark);
  letter-spacing: -.01em;
  padding-bottom: .85rem;
  margin-bottom: 1rem;
  border-bottom: 2px solid var(--color-bg-brand);
  position: relative;
  display: inline-block;
  align-self: flex-start;
  padding-right: .5rem;
}

.fnb-all__list {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.fnb-all__list li {
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  font-size: var(--text-sm);
  color: var(--color-dark-2);
  line-height: 1.5;
  letter-spacing: -.01em;
  padding: .1rem 0;
}

.fnb-all__list li::before {
  content: '';
  flex-shrink: 0;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-bg-brand);
  margin-top: .55rem;
}


.fnb-carousel {
  overflow: hidden;
  border-radius: var(--radius-lg);
}
.fnb-carousel__track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--color-gray-4) transparent;
  padding-bottom: .5rem;
}
.fnb-carousel__slide {
  flex: 0 0 calc((100% - 3rem) / 4);
  min-width: 220px;
  scroll-snap-align: start;
  background: var(--color-white);
  border: 1px solid var(--color-gray-5);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
@media (max-width: 899px) {
  .fnb-carousel__slide { flex-basis: calc((100% - 1rem) / 2); }
}
.fnb-carousel__img {
  aspect-ratio: 4 / 3;
  background: var(--color-gray-6);
}
.fnb-carousel__img img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.fnb-carousel__label {
  padding: .8rem 1rem;
  font-size: var(--text-sm);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-align: center;
  letter-spacing: -.01em;
}
