/* layout.css — 프리미어 프로 스타일 메인 그리드
   행: 상단바 / 상단 패널 / 하단 타임라인
   열: 라이브러리 / 프로그램 모니터 / 우측 탭 */

.app {
  display: grid;
  grid-template-rows: minmax(300px, 1fr) 1fr;
  width: 100vw;
  height: 100vh;
  gap: 8px;
  padding: 8px;
  padding-top: calc(var(--safe-top) + 8px);
  padding-bottom: calc(var(--safe-bottom) + 8px);
  overflow: hidden;
}

.upper-row    { grid-row: 1; display: flex; gap: 8px; align-items: stretch; min-height: 0; min-width: 0; }
.timeline-area{ grid-row: 2; display: grid; grid-template-rows: auto 1fr; gap: 8px; min-height: 0; }

/* 상단 행: 라이브러리 + 프로그램 모니터 + 우측 탭 = flex.
   프로그램 모니터는 16:9 고정, 좌우는 남은 공간 균등 분할 → 빈 영역 없음. */
.library    { flex: 1 1 0; min-width: 200px; }
.right-tabs { flex: 1 1 0; min-width: 200px; }

/* 패널 공통 */
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.panel .panel-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--line-soft);
  font-size: 12px;
  color: var(--muted);
}
.panel .panel-head strong { color: var(--text); font-size: 13px; flex: 1; }
.panel .panel-body {
  flex: 1;
  min-height: 0;
  padding: 10px;
  overflow: hidden;
}

/* 좁아지면 좌·우 패널 숨기고 1열로 */
@media (max-width: 1100px) {
  .app {
    grid-template-rows: minmax(220px, 1fr) 1fr;
  }
  .library, .right-tabs { display: none; }
}
