/* ══════════════════════════════════════════════════════
   CSS 변수
══════════════════════════════════════════════════════ */
:root {
  --bg:          #1a1d2e;
  --nav-bg:      #161a27;
  --topbar-bg:   #0f1118;
  --card-bg:     #1e2230;
  --border:      #2b3050;
  --accent:      #4C72B0;
  --accent-h:    #5a84c8;
  --text:        #d4d4d4;
  --text-dim:    #8899aa;
  --text-bright: #ffffff;
  --danger:      #e05c5c;
  --radius:      6px;
  --nav-w:       280px;
  --top-h:       44px;
}

/* ══════════════════════════════════════════════════════
   리셋 & 기본
══════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Malgun Gothic', 'Apple SD Gothic Neo', sans-serif;
  font-size: 13px;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ══════════════════════════════════════════════════════
   상단 헤더
══════════════════════════════════════════════════════ */
#topbar {
  height: var(--top-h);
  background: var(--topbar-bg);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 16px;
  flex-shrink: 0;
}

#logo {
  font-size: 15px;
  font-weight: bold;
  color: var(--text-bright);
  white-space: nowrap;
}

/* (controls 제거됨 — 네비 패널로 이동) */

/* 조회 컨트롤 블록 */
#query-bar {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 10px 8px;
  border-bottom: 1px solid var(--border);
  background: var(--nav-bg);
}
#ticker-input {
  width: 100%;
  padding: 7px 10px;
  background: #ffffff;
  color: #111;
  border: 1px solid #aaa;
  border-radius: var(--radius);
  font-size: 13px;
  outline: none;
  letter-spacing: 1px;
}
#ticker-input:focus { border-color: var(--accent); }
#query-row2 {
  display: flex;
  gap: 6px;
}
#years-select {
  flex: 1;
  padding: 6px 8px;
  background: #252a3a;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 12px;
  cursor: pointer;
  outline: none;
}
#run-btn {
  flex: 2;
  padding: 6px 0;
  background: var(--accent);
  color: #fff;
  border: none;
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: bold;
  cursor: pointer;
  transition: background 0.15s;
  white-space: nowrap;
}
#run-btn:hover    { background: var(--accent-h); }
#run-btn:active   { background: #3a5a9a; }
#run-btn:disabled { background: #3a4a6a; cursor: not-allowed; }

/* 정렬 바 */
#sort-bar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-bottom: 1px solid var(--border);
  background: var(--nav-bg);
}
.sort-lbl {
  font-size: 11px;
  color: var(--text-dim);
  margin-right: 2px;
}
.sort-btn {
  padding: 2px 7px;
  background: #252a3a;
  color: var(--text-dim);
  border: 1px solid #3a4060;
  border-radius: 3px;
  font-size: 11px;
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
}
.sort-btn:hover  { background: #2e3448; color: var(--text); }
.sort-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ══════════════════════════════════════════════════════
   레이아웃
══════════════════════════════════════════════════════ */
#layout {
  display: flex;
  flex: 1;
  overflow: hidden;
}

/* ══════════════════════════════════════════════════════
   좌측 네비
══════════════════════════════════════════════════════ */
#nav-panel {
  width: var(--nav-w);
  background: var(--nav-bg);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  overflow: hidden;
}

#nav-title {
  padding: 10px 14px;
  font-size: 11px;
  font-weight: bold;
  color: #7080a0;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

#nav-search {
  width: 100%;
  padding: 8px 12px;
  background: #1e2230;
  color: var(--text);
  border: none;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  outline: none;
}
#nav-search::placeholder { color: #556070; }
#nav-search:focus { background: #252b3e; }

/* 로딩 바 */
#nav-loading { height: 3px; overflow: hidden; }
#nav-loading.hidden { display: none; }
.loading-bar {
  height: 3px;
  background: var(--accent);
  animation: slide 1.4s linear infinite;
  width: 40%;
}
@keyframes slide {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(700%); }
}

/* 탭 버튼 */
#tab-bar {
  display: flex;
  border-bottom: 1px solid var(--border);
}
.tab-btn {
  flex: 1;
  padding: 7px 4px;
  background: transparent;
  color: var(--text-dim);
  border: none;
  border-bottom: 2px solid transparent;
  font-size: 12px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.tab-btn.active {
  color: var(--text-bright);
  border-bottom-color: var(--accent);
}
.tab-btn:hover:not(.active) { color: var(--text); }

/* 종목 패널 */
.stock-panel {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
}
.stock-panel.hidden { display: none; }
.stock-panel::-webkit-scrollbar { width: 4px; }
.stock-panel::-webkit-scrollbar-track { background: transparent; }
.stock-panel::-webkit-scrollbar-thumb { background: #3a4060; border-radius: 2px; }

.placeholder-msg {
  padding: 16px 14px;
  color: var(--text-dim);
  font-size: 12px;
}

/* 종목 아이템 */
.stock-item {
  padding: 5px 14px;
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 12px;
  color: var(--text);
  transition: background 0.1s;
}
.stock-item:hover    { background: #242840; }
.stock-item.active   { background: #2d3a5e; color: #fff; }
.stock-item .num     { color: #455060; margin-right: 6px; font-size: 11px; }
.stock-item .code    { color: #556070; font-size: 11px; margin-left: 6px; }

/* ══════════════════════════════════════════════════════
   메인 영역
══════════════════════════════════════════════════════ */
#main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow-y: auto;
  padding: 24px;
  position: relative;
}
#main.has-chart {
  align-items: flex-start;
  justify-content: flex-start;
}
#main::-webkit-scrollbar { width: 6px; }
#main::-webkit-scrollbar-thumb { background: #3a4060; border-radius: 3px; }

/* 웰컴 화면 */
#welcome {
  text-align: center;
  pointer-events: none;
  user-select: none;
}
.welcome-icon { font-size: 56px; margin-bottom: 16px; }
.welcome-title {
  font-size: 18px;
  font-weight: bold;
  color: var(--text-bright);
  margin-bottom: 10px;
}
.welcome-sub { color: var(--text-dim); line-height: 1.7; }

/* 로딩 오버레이 */
#loading-overlay {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  width: 100%;
  max-width: 560px;
}
#loading-overlay.hidden { display: none; }

#spinner {
  width: 44px;
  height: 44px;
  border: 4px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

#log-area {
  width: 100%;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 12px 16px;
  font-size: 12px;
  font-family: 'Consolas', monospace;
  color: #99b0c8;
  line-height: 1.7;
  max-height: 260px;
  overflow-y: auto;
}

/* 차트 영역 */
#chart-wrap {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: 100%;
}
#chart-wrap.hidden { display: none; }

#chart-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding-bottom: 10px;
  width: 100%;
}

#chart-title {
  font-size: 16px;
  font-weight: bold;
  color: var(--text-bright);
}

#zoom-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 4px 12px;
}
.zoom-lbl {
  font-size: 11px;
  color: var(--text-dim);
  white-space: nowrap;
}
.zoom-btn {
  width: 22px;
  height: 22px;
  background: #2a3050;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 50%;
  font-size: 15px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.zoom-btn:hover { background: var(--accent); color: #fff; }

#zoom-slider {
  width: 110px;
  accent-color: var(--accent);
  cursor: pointer;
}
#zoom-pct {
  font-size: 11px;
  color: var(--text-dim);
  min-width: 36px;
  text-align: right;
}

#chart-scroll {
  overflow-x: auto;
  overflow-y: hidden;
  border-radius: var(--radius);
}
#chart-scroll::-webkit-scrollbar { height: 5px; }
#chart-scroll::-webkit-scrollbar-thumb { background: #3a4060; border-radius: 3px; }

#chart-img {
  display: block;
  /* width 는 JS에서 커준다 */
  border-radius: var(--radius);
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
  background: #fff;
  transition: width 0.15s;
}

/* 에러 박스 */
#error-box {
  background: #3a1a1a;
  border: 1px solid var(--danger);
  border-radius: var(--radius);
  padding: 14px 20px;
  color: #f08080;
  max-width: 560px;
  text-align: center;
}
#error-box.hidden { display: none; }

/* ══════════════════════════════════════════════════════
   유틸
══════════════════════════════════════════════════════ */
.hidden { display: none !important; }
