/* ============================================================================
 * KPOPVIEW V2.0 — Layout (Header / Footer / Bottom Tab / Nav)
 * ============================================================================
 * 모바일 & PC 독립 레이아웃. 각각 플랫폼 최적화.
 * ============================================================================ */

/* ============================================================================
 * Header (공통 → 브레이크포인트별 분리)
 * ============================================================================ */

.kv-header {
  position: sticky;
  top: 0;
  z-index: var(--kv-z-sticky);
  background: rgba(11, 11, 15, 0.80);
  backdrop-filter: blur(12px) saturate(180%);
  border-bottom: 1px solid var(--kv-border);
  transition: height var(--kv-duration-fast);
}

.kv-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--kv-space-4);
  max-width: var(--kv-container-max);
  margin: 0 auto;
  padding: 0 var(--kv-space-4);
  height: var(--kv-header-h-desktop);
}

.kv-header__logo {
  display: flex;
  align-items: center;
  height: 100%;
  flex-shrink: 0;
}
.kv-header__logo img, .kv-header__logo svg {
  height: 28px;
  width: auto;
}

.kv-header__nav {
  display: none;                  /* 모바일에서는 숨김 */
  gap: var(--kv-space-6);
  align-items: center;
}
.kv-header__nav a {
  font-size: var(--kv-text-body-md);
  font-weight: var(--kv-weight-medium);
  color: var(--kv-text-secondary);
  transition: color var(--kv-duration-fast);
}
.kv-header__nav a:hover { color: var(--kv-text-primary); }
.kv-header__nav a.is-active { color: var(--kv-text-primary); }

.kv-header__tools {
  display: flex;
  align-items: center;
  gap: var(--kv-space-3);
}
.kv-header__lang {
  display: flex;
  gap: var(--kv-space-1);
  padding: 2px;
  background: var(--kv-surface);
  border-radius: var(--kv-radius-full);
  font-size: var(--kv-text-caption);
}
.kv-header__lang a {
  padding: 4px 10px;
  border-radius: var(--kv-radius-full);
  color: var(--kv-text-muted);
}
.kv-header__lang a.is-active {
  background: var(--kv-primary);
  color: #fff;
}

.kv-header__menu-toggle {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: var(--kv-radius-2);
}
.kv-header__menu-toggle:hover { background: var(--kv-surface); }

/* 스크롤 시 compact 모드 */
.kv-header.is-compact .kv-header__inner { height: var(--kv-header-h-compact); }

/* ── PC에서 확장 (1024+) ── */
@media (min-width: 1024px) {
  .kv-header__inner { padding: 0 var(--kv-space-6); }
  .kv-header__nav { display: flex; }
  .kv-header__menu-toggle { display: none; }
}
@media (min-width: 1280px) {
  .kv-header__inner { padding: 0 var(--kv-space-8); }
}

/* ============================================================================
 * Bottom Tab Bar (모바일 전용)
 * ============================================================================ */

.kv-bottom-tab {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--kv-z-sticky);
  display: flex;
  background: rgba(22, 22, 28, 0.96);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--kv-border);
  padding-bottom: env(safe-area-inset-bottom);
}

.kv-bottom-tab__item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  height: var(--kv-bottom-tab-h);
  color: var(--kv-text-muted);
  position: relative;
}
.kv-bottom-tab__icon { width: 24px; height: 24px; }
.kv-bottom-tab__label { font-size: 10px; font-weight: var(--kv-weight-medium); }

.kv-bottom-tab__item.is-active { color: var(--kv-primary); }
.kv-bottom-tab__item.is-active::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 2px;
  background: var(--kv-primary);
  border-radius: 0 0 var(--kv-radius-full) var(--kv-radius-full);
}

/* PC에서는 숨김 */
@media (min-width: 1024px) {
  .kv-bottom-tab { display: none; }
  body { padding-bottom: 0; }
}

/* 모바일 바디에 하단 탭바 높이만큼 padding */
@media (max-width: 1023px) {
  body { padding-bottom: calc(var(--kv-bottom-tab-h) + env(safe-area-inset-bottom)); }
}

/* ============================================================================
 * Footer
 * ============================================================================ */

.kv-footer {
  background: var(--kv-surface);
  border-top: 1px solid var(--kv-border);
  padding: var(--kv-space-16) 0 var(--kv-space-8);
  margin-top: var(--kv-space-16);
}
.kv-footer__inner {
  max-width: var(--kv-container-max);
  margin: 0 auto;
  padding: 0 var(--kv-space-4);
}
.kv-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--kv-space-4) var(--kv-space-6);
  margin-bottom: var(--kv-space-8);
}
.kv-footer__links a {
  color: var(--kv-text-secondary);
  font-size: var(--kv-text-body-sm);
  transition: color var(--kv-duration-fast);
}
.kv-footer__links a:hover { color: var(--kv-text-primary); }

.kv-footer__social {
  display: flex;
  gap: var(--kv-space-3);
  margin-bottom: var(--kv-space-6);
}
.kv-footer__social a {
  display: inline-flex;
  width: 40px;
  height: 40px;
  align-items: center;
  justify-content: center;
  background: var(--kv-surface-elevated);
  border-radius: var(--kv-radius-full);
  color: var(--kv-text-secondary);
  transition: color var(--kv-duration-fast);
}
.kv-footer__social a:hover { color: var(--kv-primary); }

.kv-footer__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--kv-space-4);
  padding-top: var(--kv-space-6);
  border-top: 1px solid var(--kv-border);
  color: var(--kv-text-muted);
  font-size: var(--kv-text-caption);
}

@media (min-width: 1024px) {
  .kv-footer__inner { padding: 0 var(--kv-space-8); }
  .kv-footer__links { gap: var(--kv-space-6) var(--kv-space-12); }
}
