/* ============================================================
   layout.css — 페이지 레이아웃 구조
   ⚠️ tokens → base → components 이후 로드
   ============================================================ */

/* ── 앱 루트 ── */
.nv-app { display: flex; flex-direction: column; min-height: 100dvh; }

/* ══════════════════════════════════════════
   헤더
══════════════════════════════════════════ */
.nv-header {
  position: fixed; top: 0; left: 0; right: 0;
  height: var(--nv-header-h);
  padding-top: env(safe-area-inset-top, 0px);
  background: var(--nv-bg-2);
  border-bottom: 1px solid var(--nv-border);
  z-index: var(--z-nav);
  display: flex; align-items: center;
  padding-left: var(--nv-sp-4); padding-right: var(--nv-sp-4);
  gap: var(--nv-sp-3);
}
.nv-header__logo {
  display: flex; align-items: center; gap: var(--nv-sp-2);
  font-weight: var(--nv-fw-bold); font-size: var(--nv-text-lg);
  color: var(--nv-text); flex-shrink: 0; user-select: none;
  cursor: pointer;
}
.nv-header__logo-dot  { color: var(--nv-primary); }
.nv-header__spacer    { flex: 1; }
.nv-header__actions   { display: flex; align-items: center; gap: var(--nv-sp-2); }
.nv-header__nvc {
  display: flex; align-items: center; gap: var(--nv-sp-1);
  font-size: var(--nv-text-sm); font-weight: var(--nv-fw-semibold);
  color: var(--nv-nvc);
}
.nv-header__menu-toggle { display: none; }

/* ══════════════════════════════════════════
   메인 레이아웃
══════════════════════════════════════════ */
.nv-layout {
  display: flex;
  margin-top: var(--nv-header-h);
  min-height: calc(100dvh - var(--nv-header-h));
}

/* ══════════════════════════════════════════
   사이드바 (데스크탑 LNB Rail)
══════════════════════════════════════════ */
.nv-sidebar {
  position: fixed;
  top: var(--nv-header-h); left: 0; bottom: 0;
  width: var(--nv-nav-w);
  background: var(--nv-bg-2);
  border-right: 1px solid var(--nv-border);
  z-index: var(--z-sidebar);
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: width var(--nv-tr-normal);
}
.nv-sidebar.is-open { width: var(--nv-nav-w-open); }

.nv-sidebar__scroll {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  padding: var(--nv-sp-2) 0;
}
.nv-sidebar__footer {
  padding: var(--nv-sp-2);
  border-top: 1px solid var(--nv-border);
}

/* ══════════════════════════════════════════
   메인 콘텐츠
══════════════════════════════════════════ */
.nv-main {
  flex: 1; margin-left: var(--nv-nav-w); min-width: 0;
  padding: var(--nv-sp-6);
  transition: margin-left var(--nv-tr-normal);
}
.nv-sidebar.is-open ~ .nv-main { margin-left: var(--nv-nav-w-open); }

/* 페이지 헤더 */
.nv-page-header { margin-bottom: var(--nv-sp-6); }
.nv-page-header__title { font-size: var(--nv-text-2xl); font-weight: var(--nv-fw-bold); }
.nv-page-header__desc  { margin-top: var(--nv-sp-2); color: var(--nv-text-2); font-size: var(--nv-text-sm); }

/* 12컬럼 그리드 */
.nv-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--nv-sp-4); }
.nv-col-3  { grid-column: span 3; }
.nv-col-4  { grid-column: span 4; }
.nv-col-6  { grid-column: span 6; }
.nv-col-8  { grid-column: span 8; }
.nv-col-9  { grid-column: span 9; }
.nv-col-12 { grid-column: span 12; }

/* ══════════════════════════════════════════
   하단 탭바 (모바일)
══════════════════════════════════════════ */
.nv-bottom-tabs {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0;
  height: var(--nv-bottom-h);
  padding-bottom: env(safe-area-inset-bottom, 20px);
  background: var(--nv-bg-2);
  border-top: 1px solid var(--nv-border);
  z-index: var(--z-nav);
  justify-content: space-around;
  align-items: flex-start;
  padding-top: var(--nv-sp-2);
}
.nv-bottom-tabs__item {
  display: flex; flex-direction: column; align-items: center;
  gap: 2px; flex: 1; cursor: pointer;
  color: var(--nv-text-3); font-size: 10px;
  transition: color var(--nv-tr-fast);
  padding: var(--nv-sp-1) 0;
}
.nv-bottom-tabs__item.is-active { color: var(--nv-primary); }
.nv-bottom-tabs__icon { font-size: 1.2rem; line-height: 1; }

/* ══════════════════════════════════════════
   모바일 풀스크린 오버레이 메뉴
══════════════════════════════════════════ */
.nv-menu-overlay {
  display: none;
  position: fixed; inset: 0;
  background: var(--nv-bg);
  z-index: var(--z-overlay);
  flex-direction: column;
  padding: var(--nv-sp-4);
  padding-top: calc(var(--nv-header-h) + var(--nv-sp-4));
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform var(--nv-tr-slow);
}
.nv-menu-overlay.is-open { transform: translateY(0); }
.nv-menu-overlay__close {
  position: absolute; top: var(--nv-sp-4); right: var(--nv-sp-4);
  font-size: 1.5rem; color: var(--nv-text-2); cursor: pointer;
}

/* ══════════════════════════════════════════
   반응형 (모바일 < 960px)
══════════════════════════════════════════ */
@media (max-width: 959px) {
  .nv-sidebar {
    transform: translateX(-100%);
    transition: transform var(--nv-tr-normal);
  }
  .nv-sidebar.is-mobile-open {
    transform: translateX(0);
    width: 280px;
  }
  .nv-main {
    margin-left: 0;
    padding: var(--nv-sp-4);
    padding-bottom: calc(var(--nv-bottom-h) + var(--nv-sp-4));
  }
  .nv-bottom-tabs { display: flex; }
  .nv-menu-overlay { display: flex; }
  .nv-header__menu-toggle { display: flex; }
  .nv-col-3, .nv-col-4, .nv-col-6 { grid-column: span 12; }
  .nv-col-8, .nv-col-9 { grid-column: span 12; }
}

@media (max-width: 480px) {
  .nv-main { padding: var(--nv-sp-3); padding-bottom: calc(var(--nv-bottom-h) + var(--nv-sp-3)); }
}
