/* ============================================================
   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); }
/* S3.45 DEF-S345-8 — manus.im 본격 차용 nav 본문 (6 영역 단독) */
.nv-header__nav {
  display: flex; align-items: center; gap: var(--nv-sp-1);
  margin-left: var(--nv-sp-4);
}
.nv-header__nav-link {
  padding: 8px 14px;
  font-size: var(--nv-text-sm); font-weight: var(--nv-fw-medium);
  color: var(--nv-text-2); text-decoration: none;
  border-radius: 8px;
  transition: color 0.15s, background 0.15s;
}
.nv-header__nav-link:hover { color: var(--nv-text); background: var(--nv-bg-2); }
.nv-header__nav-link:focus-visible { outline: 2px solid var(--nv-primary); outline-offset: 2px; }
@media (max-width: 900px) { .nv-header__nav { display: none; } }
.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; }

/* S3.45 DEF-S345-9 — utility-only footer (manus 안 minimal 정합) */
/* mega footer 6 칼럼 (S3.46 L-2) — 외부 평균 6 정합 (Mighty/Linear/Discord/Slack/Figma/manus) */
.nv-footer {
  border-top: 1px solid var(--nv-border);
  background: var(--nv-bg);
  padding: 48px 24px 24px;
  margin-top: 64px;
}
.nv-footer__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.nv-footer__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 32px;
  margin-bottom: 32px;
}
.nv-footer__col { min-width: 0; }
.nv-footer__title {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--nv-text);
  margin: 0 0 12px;
  letter-spacing: 0.02em;
}
.nv-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.nv-footer__link {
  color: var(--nv-text-2);
  text-decoration: none;
  font-size: 0.85rem;
  transition: color 0.15s;
}
.nv-footer__link:hover { color: var(--nv-text); text-decoration: underline; }
.nv-footer__link:focus-visible { outline: 2px solid var(--nv-primary); outline-offset: 2px; }
.nv-footer__bottom {
  border-top: 1px solid var(--nv-border);
  padding-top: 20px;
}
.nv-footer__copyright {
  color: var(--nv-text-3);
  font-size: 0.8rem;
}
/* 태블릿 = 3 칼럼 */
@media (max-width: 960px) {
  .nv-footer__grid { grid-template-columns: repeat(3, 1fr); gap: 24px; }
}
/* 모바일 = 2 칼럼 (외부 표준 정합) */
@media (max-width: 600px) {
  .nv-footer__grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}

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

/* ══════════════════════════════════════════
   사이드바 (S3.46 L-1 — 인증 후 단독 노출 / 외부 20/20 정합)
   비인증 = display:none (랜딩 안 = 사이드바 0 정합)
   인증 (html.is-authenticated) = display:flex
   외부 자료: https://docsallover.com/blog/ui-ux/spa-routing-and-navigation-best-practices/
══════════════════════════════════════════ */
.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: none;
  flex-direction: column;
  overflow: hidden;
  transition: width var(--nv-tr-normal);
}
html.is-authenticated .nv-sidebar { display: flex; }
.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: 0; min-width: 0;
  padding: var(--nv-sp-6);
  transition: margin-left var(--nv-tr-normal);
}
html.is-authenticated .nv-main { margin-left: var(--nv-nav-w); }
html.is-authenticated .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; }
  /* 데스크탑 LNB 토글은 모바일에서 hide — 햄버거 2개 노출 결함 정정 (S3.39) */
  #nv-sidebar-toggle { display: none; }
  .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)); }
}
