/* StockBoard 목업 — 공통 테마
   다크모드 · Pretendard · 컬러 팔레트(아래 변수만 바꾸면 전체 테마 교체 가능) */

:root {
  /* 배경/표면 */
  --bg: #0B0E14;
  --bg-elev: #151A23;
  --bg-elev2: #1C222D;
  --border: #2A313C;
  --border-soft: #222834;
  /* 텍스트 */
  --text: #E6EAF2;
  --muted: #9BA6B7;
  --dim: #6B7585;
  /* 강조/의미 */
  --accent: #6E8BFF;
  --accent2: #8B5CF6;
  --pos: #36C28B;
  --neg: #F26D6D;
  --gold: #D9B36C;
  /* 차트 시리즈 */
  --c1: #6E8BFF;
  --c2: #36C28B;
  --c3: #D9B36C;
  --radius: 12px;
  --radius-sm: 8px;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Malgun Gothic', sans-serif;
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  word-break: keep-all;        /* 한국어 단어(고유명사 포함) 중간 잘림 금지 — 어절 단위로만 줄바꿈 */
  overflow-wrap: normal;
}

a { color: inherit; text-decoration: none; }
.num { font-variant-numeric: tabular-nums; }

/* ===== Top bar ===== */
.topbar {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; gap: 16px;
  padding: 12px 24px;
  background: rgba(11,14,20,0.85);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}
.brand {
  font-size: 22px; font-weight: 800; letter-spacing: -0.02em;
  color: var(--text); white-space: nowrap;
}
.brand .dot { color: var(--accent); }
.topbar .search {
  flex: 1; display: flex; justify-content: center;
}
.search-box {
  display: flex; align-items: center; gap: 8px;
  width: 100%; max-width: 520px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 999px; padding: 8px 16px;
}
.search-box:focus-within { border-color: var(--accent); }
.search-box input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--text); font-size: 18px; font-family: inherit;
}
.search-box input::placeholder { color: var(--dim); }
.search-box .ico { color: var(--dim); }
.topbar .right { white-space: nowrap; }
.navlink {
  color: var(--text); font-size: 16px; font-weight: 600; padding: 8px 16px;
  border: 1px solid var(--border); border-radius: 999px; background: var(--bg-elev);
  display: inline-flex; align-items: center; gap: 6px; transition: border-color .12s, background .12s;
}
.navlink::before { content: "\2606"; color: var(--gold); font-size: 17px; line-height: 1; }
.navlink:hover { color: var(--text); background: var(--bg-elev2); border-color: var(--accent); }

/* ===== Layout ===== */
.container { max-width: 1180px; margin: 0 auto; padding: 28px 24px 64px; }

/* ===== 계열사 모니터링 — 카드 그리드 ===== */
.mon-grid { display: grid; gap: 16px; grid-template-columns: repeat(2, 1fr); }
@media (max-width: 980px) { .mon-grid { grid-template-columns: 1fr; } }
.mon-card { cursor: pointer; transition: border-color .12s, transform .12s; }
.mon-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.mon-card .co-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 10px; }
.mon-card .co-head .co-name { font-size: 20px; font-weight: 700; }
.mon-row { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; font-size: 15px; }
.mon-row .mon-key { color: var(--muted); font-size: 14px; }
.mon-row .mon-val { font-weight: 600; font-size: 17px; }
/* 헤드 row: [현재가/시총] [주가차트] 가로 배치 */
.mon-head-row { display: flex; align-items: center; gap: 16px; margin-bottom: 6px; }
.mon-head-row .mon-pricecol { flex-shrink: 0; flex-wrap: nowrap; }
.mon-head-row .mon-sparkbox { flex: 1; min-width: 0; height: 95px; position: relative; }
.mon-sec-title { font-size: 14px; color: var(--muted); margin: 14px 0 6px; padding-top: 10px; border-top: 1px solid var(--border-soft); display: flex; justify-content: space-between; align-items: baseline; }
.mon-sec-title:first-child, .mon-card > .mon-sec-title:first-of-type { border-top: none; padding-top: 0; }
.mon-fin { width: 100%; font-size: 14px; }
.mon-fin thead th { font-size: 13px; padding: 4px 8px; }
.mon-fin tbody td { padding: 4px 8px; }
.mon-list { list-style: none; padding: 0; margin: 0; font-size: 14px; }
.mon-list li { padding: 4px 0; border-bottom: 1px solid var(--border-soft); line-height: 1.5; }
.mon-list li:last-child { border-bottom: none; }
.mon-list a { color: var(--text); text-decoration: none; }
.mon-list a:hover { color: var(--accent); text-decoration: underline; }
/* 뉴스 행: 한 줄로 고정 (긴 제목은 ... 말줄임) */
.mon-list li.news-row { display: flex; align-items: baseline; gap: 8px; }
.mon-list li.news-row .news-date { flex-shrink: 0; }
.mon-list li.news-row .news-title { flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mon-list li.news-row .news-src { flex-shrink: 0; font-size: 12px; }
.mon-more {
  display: inline-block; margin-top: 6px; padding: 0;
  background: none; border: none; font-family: inherit; cursor: pointer;
  color: var(--muted); font-size: 13px; text-decoration: none;
}
.mon-more:hover { color: var(--accent); text-decoration: underline; }

/* ===== IR 분석 — 업로드 드롭존 + 파일 리스트 ===== */
.ir-drop {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; padding: 40px 24px;
  background: var(--bg-elev); border: 2px dashed var(--border); border-radius: var(--radius);
  text-align: center; transition: border-color .12s, background .12s;
}
.ir-drop.over { border-color: var(--accent); background: var(--bg-elev2); }
.ir-drop-icon { font-size: 36px; color: var(--accent); line-height: 1; }
.ir-drop-title { font-size: 17px; color: var(--text); }
.ir-drop-hint { font-size: 14px; color: var(--muted); }
.ir-drop input[type="file"] { display: none; }

.ir-sec-title { font-size: 17px; font-weight: 600; margin: 28px 0 10px; color: var(--text); }
.ir-list { display: flex; flex-direction: column; gap: 8px; }
.ir-file-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-sm);
}
.ir-file-row .ir-file-icon {
  width: 36px; height: 36px; flex-shrink: 0; display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev2); border-radius: var(--radius-sm); font-size: 12px; font-weight: 700; color: var(--accent);
}
.ir-file-row .ir-file-main { flex: 1; min-width: 0; }
.ir-file-row .ir-file-name {
  font-size: 15px; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ir-file-row .ir-file-meta { font-size: 13px; color: var(--muted); margin-top: 3px; }
.ir-file-row .ir-file-del {
  background: none; border: 1px solid var(--border); color: var(--muted); cursor: pointer;
  padding: 6px 10px; border-radius: var(--radius-sm); font-size: 13px; transition: color .12s, border-color .12s, background .12s;
}
.ir-file-row .ir-file-del:hover { color: #fff; background: var(--neg); border-color: var(--neg); }

.ir-progress { margin-top: 14px; font-size: 14px; color: var(--muted); }
.ir-progress.ok { color: var(--pos); }
.ir-progress.err { color: var(--neg); }

/* IR 분석 — 자료 그룹 카드 (1 그룹 = 1 리포트, 파일 N개) */
.ir-groups { display: flex; flex-direction: column; gap: 14px; }
.ir-group {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 14px 16px;
}
.ir-group-head {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border-soft);
}
/* 제목은 남는 폭을 차지하고 길면 말줄임 → 우측 액션 버튼과 절대 겹치지 않음 */
.ir-group-title {
  font-size: 16px; font-weight: 700; color: var(--text);
  flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ir-group-count { font-size: 13px; color: var(--muted); font-weight: 400; flex-shrink: 0; }
.ir-group-badge {
  font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 999px; flex-shrink: 0;
  color: var(--pos); background: rgba(54,194,139,0.12); border: 1px solid rgba(54,194,139,0.35);
}
/* 헤더 우측 액션 묶음 — 폭이 줄어도 버튼은 유지하고 제목이 먼저 줄어듦 */
.ir-group-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
/* 좁은 폭(모바일)에서는 헤더를 2행으로: 제목 행 + 액션 행 */
@media (max-width: 560px) {
  .ir-group-head { flex-wrap: wrap; }
  .ir-group-actions { margin-left: auto; }
}
.ir-group .ir-list { gap: 8px; }
/* 그룹 내부 파일행은 한 단계 안쪽 톤 */
.ir-group .ir-file-row { background: var(--bg-elev2); }

/* IR 분석 — 파일 행 액션 버튼 */
.ir-file-row .ir-file-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.btn.btn-sm { padding: 6px 12px; font-size: 13px; }
.btn.btn-link {
  background: none; border: none; color: var(--accent); padding: 6px 10px; font-size: 14px; cursor: pointer;
}
.btn.btn-link:hover { text-decoration: underline; }

/* IR 분석 보고서 페이지 */
.report-header { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.report-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; flex-shrink: 0; }

/* IR 분석 사용량·비용 요약 (보고서 상단) */
.report-usage {
  display: flex; flex-wrap: wrap; gap: 10px 22px; align-items: baseline;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 12px 16px; margin-bottom: 18px; font-size: 14px;
}
.report-usage .ru-item { display: flex; align-items: baseline; gap: 8px; }
.report-usage .ru-k { color: var(--muted); font-size: 13px; }
.report-usage .ru-v { color: var(--text); font-weight: 600; }
.report-usage .ru-cost { color: var(--accent); }
.report-usage .ru-sub { color: var(--muted); font-weight: 400; font-size: 13px; }
.report-meta { font-size: 14px; color: var(--muted); }
.report-grid { display: flex; flex-direction: column; gap: 16px; }
.report-sec {
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px 20px;
}
.report-sec-title { font-size: 18px; font-weight: 700; margin: 0 0 12px; color: var(--text); }
.report-badge {
  display: inline-block; font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 999px;
  margin-bottom: 10px; vertical-align: middle;
}
.report-badge.enrich { color: var(--accent); background: rgba(110,139,255,0.12); border: 1px solid rgba(110,139,255,0.35); }

/* 각 섹션 하단 '맨 위로' 링크 */
.sec-foot { display: flex; justify-content: flex-end; margin-top: 14px; padding-top: 10px; border-top: 1px solid var(--border-soft); }
.back-to-top {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 13px; color: var(--muted); text-decoration: none;
  padding: 4px 10px; border-radius: var(--radius-sm);
  transition: color .12s, background .12s;
}
.back-to-top:hover { color: var(--accent); background: var(--bg-elev2); }
.report-sec .summary { font-size: 16px; line-height: 1.65; color: var(--text); margin: 0 0 12px; }
.report-sec .placeholder { font-size: 14px; color: var(--dim); font-style: italic; }

/* 재무정보 — 최신 KPI 카드 + 자세히 보기 */
.fin-kpi-title { font-size: 15px; font-weight: 600; margin: 14px 0 6px; color: var(--text); }
.fin-kpi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.fin-kpi { background: var(--bg-elev2); border: 1px solid var(--border-soft); border-radius: var(--radius-sm); padding: 10px 12px; }
.fin-kpi-k { color: var(--muted); font-size: 13px; }
.fin-kpi-v { color: var(--text); font-weight: 700; font-size: 18px; margin-top: 3px; word-break: keep-all; }
.fin-detail-btn { margin-top: 16px; }
.fin-detail { border-top: 1px solid var(--border-soft); padding-top: 4px; }
@media (max-width: 560px) { .fin-kpi-grid { grid-template-columns: 1fr; } }

/* 회사개요 KV */
.report-kv { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 18px; }
@media (max-width: 720px) { .report-kv { grid-template-columns: 1fr; } }
.report-kv .kv-row { display: flex; justify-content: space-between; gap: 12px; padding: 7px 0; border-bottom: 1px solid var(--border-soft); font-size: 16px; }
.report-kv .kv-row .k { color: var(--muted); flex-shrink: 0; }
.report-kv .kv-row .v { color: var(--text); text-align: right; }

/* 사업부문 차트 + 리스트 */
.seg-chart-wrap { position: relative; height: 240px; margin: 8px 0 16px; }
.seg-list { display: flex; flex-direction: column; gap: 8px; }
.seg-item {
  display: grid; grid-template-columns: minmax(140px, 1fr) 100px 80px;
  gap: 12px; padding: 10px 12px; background: var(--bg-elev2); border-radius: var(--radius-sm);
  align-items: baseline; font-size: 15px;
}
.seg-item .seg-name { font-weight: 600; color: var(--text); }
.seg-item .seg-desc { color: var(--muted); font-size: 14px; grid-column: 1 / -1; margin-top: 2px; }
.seg-item .seg-rev { text-align: right; color: var(--text); }
.seg-item .seg-pct { text-align: right; color: var(--accent); }
/* 사업부문 하위(세부 솔루션·브랜드) — 대분류 카드 내부 들여쓰기 목록 */
.seg-item .seg-sub {
  grid-column: 1 / -1; margin: 8px 0 0; padding: 8px 0 0 14px;
  list-style: none; border-top: 1px solid var(--border-soft); display: flex; flex-direction: column; gap: 4px;
}
.seg-item .seg-sub li { font-size: 14px; line-height: 1.5; position: relative; padding-left: 12px; }
.seg-item .seg-sub li::before { content: "·"; position: absolute; left: 0; color: var(--dim); }
.seg-item .seg-sub .seg-sub-name { color: var(--text); font-weight: 600; }
.seg-item .seg-sub .seg-sub-desc { color: var(--muted); }

/* 특징 카드들 */
.feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 720px) { .feature-grid { grid-template-columns: 1fr; } }
.feature-card { background: var(--bg-elev2); border-radius: var(--radius-sm); padding: 12px 14px; }
.feature-card .ft-title { font-weight: 600; color: var(--accent); margin-bottom: 4px; font-size: 15px; }
.feature-card .ft-desc { font-size: 14px; line-height: 1.55; color: var(--text); }

/* 투자고려 — 기회/리스크 */
.risk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 720px) { .risk-grid { grid-template-columns: 1fr; } }
.risk-box { padding: 12px 14px; border-radius: var(--radius-sm); }
.risk-box.opp { background: rgba(54,194,139,0.08); border-left: 3px solid var(--pos); }
.risk-box.risk { background: rgba(242,109,109,0.08); border-left: 3px solid var(--neg); }
.risk-box .tag { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.risk-box.opp .tag { color: var(--pos); }
.risk-box.risk .tag { color: var(--neg); }
.risk-box .body { font-size: 14px; line-height: 1.55; color: var(--text); }

/* 산업·경쟁 — 자사 시장지위(경쟁사 표 위 한 줄/박스). 빈 문자열이면 JS가 미출력 */
.self-position { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap;
  padding: 10px 14px; margin-bottom: 12px; border-radius: var(--radius-sm);
  background: rgba(110,139,255,0.08); border-left: 3px solid var(--accent); }
.self-position-tag { flex: 0 0 auto; font-size: 13px; font-weight: 700; color: var(--accent); white-space: nowrap; }
.self-position-text { flex: 1 1 auto; min-width: 0; font-size: 15px; line-height: 1.55; color: var(--text); }

/* ===== 메인 랜딩 — 타이틀 + 3개 메뉴 카드 ===== */
.landing-hero { padding: 36px 0 20px; text-align: center; }
.landing-title { font-size: 30px; font-weight: 700; margin: 0 0 10px; letter-spacing: -0.02em; }
.landing-sub { font-size: 17px; color: var(--muted); margin: 0; }
.menu-grid {
  display: grid; gap: 20px;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 36px;
}
.menu-card {
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  min-height: 220px; padding: 28px 24px; text-align: center;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  color: var(--text); text-decoration: none; cursor: pointer;
  transition: border-color .12s, transform .12s, background .12s;
}
.menu-card:hover { border-color: var(--accent); background: var(--bg-elev2); transform: translateY(-2px); }
.menu-card-title { font-size: 22px; font-weight: 700; margin: 0 0 10px; }
.menu-card-desc { font-size: 15px; color: var(--muted); line-height: 1.55; max-width: 280px; }
.menu-card-tag { display: inline-block; font-size: 13px; color: var(--dim); border: 1px solid var(--border-soft); border-radius: 999px; padding: 2px 10px; margin-top: 14px; }
@media (max-width: 880px) { .menu-grid { grid-template-columns: 1fr; } }

/* ===== 상세 페이지 — 관심기업 목록으로 돌아가기 ===== */
.back-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--muted); text-decoration: none; font-size: 15px;
  padding: 6px 10px; margin: 0 0 12px -10px; border-radius: var(--radius-sm);
  transition: color .12s, background .12s;
}
.back-link:hover { color: var(--text); background: var(--bg-elev); }

/* ===== 상세 페이지 점프 내비 (가로 sticky 바) ===== */
html { scroll-behavior: smooth; }
.container section { scroll-margin-top: 118px; }   /* 토픽바 + 점프바 높이만큼 오프셋 */
.jump-nav {
  position: sticky; top: 60px; z-index: 15;
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  background: rgba(11,14,20,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  margin: 0 0 18px; padding: 8px 0;
}
.jump-nav .jump-nav-label { font-size: 13px; color: var(--dim); margin-right: 2px; }
.jump-nav a {
  color: var(--text); font-size: 14px; font-weight: 500; text-decoration: none; white-space: nowrap;
  padding: 5px 12px; border: 1px solid var(--border); border-radius: 999px;
  background: var(--bg-elev); transition: color .12s, background .12s, border-color .12s;
}
.jump-nav a:hover { color: var(--text); background: var(--bg-elev2); border-color: var(--accent); }
.jump-nav a.active { color: #fff; background: var(--accent); border-color: var(--accent); font-weight: 600; }
.page-title { font-size: 24px; font-weight: 700; margin: 4px 0 4px; }
.page-sub { color: var(--muted); font-size: 17px; margin: 0 0 20px; }

.grid { display: grid; gap: 16px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cards { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

/* ===== Card ===== */
.card {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px;
}
.card-header { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; margin-bottom: 14px; }
.card-title { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.card-sub { font-size: 15px; color: var(--dim); }

/* ===== Badges / chips / tags ===== */
.badge {
  display: inline-block; font-size: 15px; font-weight: 600;
  padding: 2px 8px; border-radius: 999px; border: 1px solid var(--border);
  color: var(--muted); background: var(--bg-elev2);
}
.badge.listed { color: #cdddff; border-color: #2f3e63; background: #16203a; }
.badge.unlisted { color: #e8d6b0; border-color: #4a3f29; background: #2a2417; }
.chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.chip {
  font-size: 16px; color: var(--muted);
  background: var(--bg-elev2); border: 1px solid var(--border);
  border-radius: 999px; padding: 3px 10px;
}
.tag { font-size: 14px; padding: 1px 6px; border-radius: 4px; vertical-align: middle; }
.tag.ai { background: #241b3a; color: #c4b0ff; border: 1px solid #3d2f63; }
.tag.warn { background: #2a2417; color: #e8d6b0; border: 1px solid #4a3f29; }
.tag.src { background: var(--bg-elev2); color: var(--dim); border: 1px solid var(--border); }

.pos { color: var(--pos); }
.neg { color: var(--neg); }

/* ===== Hero ===== */
.hero { padding: 8px 0 18px; border-bottom: 1px solid var(--border-soft); margin-bottom: 20px; }
.hero-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.hero-title { font-size: 30px; font-weight: 800; letter-spacing: -0.02em; margin: 0; }
.hero-en { font-size: 19px; font-weight: 500; color: var(--dim); margin-left: 6px; }
.hero-tagline { color: var(--muted); margin: 12px 0 0; max-width: 820px; font-size: 17.5px; }

/* ===== KPI ===== */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(146px, 1fr)); gap: 10px; margin-bottom: 16px; }
.kpi { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); padding: 10px 14px; }
.kpi-label { font-size: 14px; color: var(--muted); margin-bottom: 4px; }
.kpi-value { font-size: 26px; font-weight: 800; letter-spacing: -0.02em; }
.kpi-unit { font-size: 16px; font-weight: 600; color: var(--muted); margin-left: 3px; }
.kpi-delta { font-size: 15px; margin-top: 4px; color: var(--dim); }
.kpi-delta.up { color: var(--pos); }
.kpi-delta.down { color: var(--neg); }

/* ===== Key-value list ===== */
.kv-list { display: flex; flex-direction: column; gap: 0; }
.kv-row { display: flex; justify-content: space-between; gap: 12px; padding: 7px 0; border-bottom: 1px solid var(--border-soft); font-size: 17px; }
.kv-row:last-child { border-bottom: none; }
.kv-row .k { color: var(--muted); flex-shrink: 0; }
.kv-row .v { text-align: right; }

/* ===== Table ===== */
table { width: 100%; border-collapse: collapse; font-size: 17px; }
thead th {
  text-align: center; font-weight: 600; color: var(--muted); font-size: 15px;
  padding: 8px 10px; border-bottom: 1px solid var(--border);
}
/* 컬럼명(헤더)은 모두 가운데정렬 — 본문 숫자 셀만 우측정렬 유지 */
tbody td.num { text-align: right; font-variant-numeric: tabular-nums; }
tbody td { padding: 8px 10px; border-bottom: 1px solid var(--border-soft); }
tbody tr:last-child td { border-bottom: none; }
tr.row-strong td { font-weight: 700; }
/* 첨부 자료 보완(doc_enrich) — 섹션 기존내용 아래 별도 표시(accent 좌측선·배지) */
.doc-sup { border-left: 3px solid var(--accent); background: rgba(110,139,255,0.07); padding: 9px 13px; margin-top: 12px; border-radius: 0 8px 8px 0; }
.doc-sup .doc-sup-label { color: var(--accent); font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 4px; }
.doc-sup .doc-sup-body { color: var(--text); font-size: 15px; line-height: 1.6; margin-top: 4px; white-space: pre-line; }

/* 컬럼 구분선(약하게) — 셀 사이 약한 세로선으로 열 구분 (고연령 가독성) */
thead th:not(:last-child), tbody td:not(:last-child) { border-right: 1px solid var(--border-soft); }
/* 표 안 보조열(dim)은 캡션용 --dim 대신 --muted 로 — 너무 흐리지 않게 */
tbody td.dim { color: var(--muted); }

/* ===== Charts ===== */
.chart-wrap { position: relative; height: 240px; margin-top: 6px; }
/* 주가 차트: 휠 줌·드래그 팬 affordance */
canvas#sparkPrice { cursor: grab; }
canvas#sparkPrice:active { cursor: grabbing; }
.unit-tag { font-size: 15px; color: var(--dim); }

/* ===== Button ===== */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 17px; font-weight: 600; cursor: pointer;
  border-radius: var(--radius-sm); padding: 8px 14px;
  border: 1px solid var(--border); background: var(--bg-elev); color: var(--text);
}
.btn:hover { border-color: var(--accent); }
.btn.primary { background: var(--accent); border-color: var(--accent); color: #0b0e14; }
.btn.primary:hover { filter: brightness(1.08); }

/* ===== Company summary card (landing/watchlist) ===== */
.co-card { cursor: pointer; transition: border-color .12s, transform .12s; position: relative; }
.co-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.co-card .co-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.co-name { font-size: 20px; font-weight: 700; }

/* 관심기업 카드 삭제 버튼 */
.wl-del {
  position: absolute; top: 10px; right: 10px; z-index: 3;
  width: 28px; height: 28px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elev2); border: 1px solid var(--border);
  color: var(--muted); font-size: 16px; line-height: 1; cursor: pointer;
  transition: color .12s, background .12s, border-color .12s; opacity: .65;
}
.co-card:hover .wl-del { opacity: 1; }
.wl-del:hover { color: #fff; background: var(--neg); border-color: var(--neg); opacity: 1; }
/* 삭제버튼이 있는 카드는 헤드 우측에 버튼 공간 확보 (배지와 겹침 방지) */
.co-card.has-del .co-head { padding-right: 36px; }

/* 카드 드래그앤드롭 위치 교체 (관심기업·계열사 모니터링 공통) */
.co-card[draggable="true"], .mon-card[draggable="true"] { cursor: grab; }
.co-card.dragging, .mon-card.dragging { opacity: .45; cursor: grabbing; }
.co-card.drop-target, .mon-card.drop-target {
  border-color: var(--accent); outline: 2px dashed var(--accent); outline-offset: 2px;
}

/* 관심기업 별표 토글 (상세 페이지 회사명 옆) */
.wl-star {
  background: none; border: none; cursor: pointer; padding: 0 0 0 10px;
  font-size: 30px; line-height: 1; color: var(--muted);
  vertical-align: middle; transition: color .15s, transform .1s;
}
.wl-star:hover { transform: scale(1.12); color: #f5c518; }
.wl-star.on { color: #f5c518; }
.co-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px 14px; margin: 10px 0; }
.co-stat { display: flex; justify-content: space-between; font-size: 16px; }
.co-stat .lbl { color: var(--dim); }
.co-spark { height: 56px; margin-top: 8px; }
.co-foot { display: flex; justify-content: space-between; align-items: baseline; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border-soft); font-size: 16px; }
.co-foot .big { font-size: 19px; font-weight: 700; }

/* ===== Section heading ===== */
.section-row { margin-bottom: 16px; }
.muted { color: var(--muted); }
.dim { color: var(--dim); }
.mt0 { margin-top: 0; } .mb0 { margin-bottom: 0; }

/* ===== Modal (관심기업 추가 확인) ===== */
.modal-overlay {
  display: none; position: fixed; inset: 0; z-index: 50;
  background: rgba(0,0,0,0.55); align-items: center; justify-content: center;
}
.modal-overlay.open { display: flex; }
.modal {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 22px; width: 320px; text-align: center;
}
.modal p { margin: 0 0 18px; }
.modal .row { display: flex; gap: 8px; justify-content: center; }

/* ===== Responsive ===== */
@media (max-width: 880px) {
  .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .topbar { flex-wrap: wrap; }
  .topbar .search { order: 3; width: 100%; }
  .hero-title { font-size: 26px; }
}

/* ===== 검색 드롭다운 ===== */
.search-dd {
  position: absolute; top: calc(100% + 6px); left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 520px; z-index: 30;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.search-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 14px; font-size: 17px; color: var(--text);
  border-bottom: 1px solid var(--border-soft);
}
.search-row:last-child { border-bottom: none; }
a.search-row:hover { background: var(--bg-elev2); }

/* ===== 로드/안내 배너 ===== */
.banner { border-radius: var(--radius-sm); padding: 10px 14px; font-size: 17px; margin-bottom: 16px; }
.banner.err { border: 1px solid var(--neg); color: var(--neg); }
.banner.info { border: 1px solid var(--border); color: var(--muted); }
.placeholder { color: var(--dim); font-size: 17px; }

/* ===== 관심기업 카드 2열 지표 ===== */
.co-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 4px 18px; margin: 10px 0; }
.co-cols .co-stat { padding: 2px 0; }

/* ===== 2026-06-03 추가 기능 스타일 ===== */
/* 주가추이 분석 (AI) 버튼 */
.btn.px-analyze-btn {
  color: #fff; background: var(--accent); border-color: var(--accent); font-size: 13px;
  animation: px-pulse 2.4s ease-in-out infinite;
}
.btn.px-analyze-btn:hover { background: var(--accent2); border-color: var(--accent2); animation: none; }
.btn.px-analyze-btn:disabled { opacity: .6; cursor: default; animation: none; }
@keyframes px-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(110,139,255,0.0); }
  50% { box-shadow: 0 0 0 4px rgba(110,139,255,0.22); }
}
/* 분석 로딩 */
.px-loading {
  display: flex; align-items: center; gap: 10px; margin-top: 12px; padding: 14px 16px;
  background: var(--bg-elev2); border: 1px solid var(--accent); border-radius: var(--radius-sm);
  color: var(--text); font-size: 15px; animation: px-pulse 2s ease-in-out infinite;
}
.px-spinner {
  width: 18px; height: 18px; flex-shrink: 0; border-radius: 50%;
  border: 2px solid var(--border); border-top-color: var(--accent); animation: px-spin .7s linear infinite;
}
@keyframes px-spin { to { transform: rotate(360deg); } }
/* 분석 결과 박스 */
.px-analysis { margin-top: 4px; }
.px-an-top {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px; margin: 12px 0 8px;
  padding: 8px 12px; background: var(--bg-elev2); border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm); font-size: 13px;
}
.px-an-top .px-an-model { color: var(--accent); font-weight: 700; }
.px-an-body { font-size: 16px; line-height: 1.7; color: var(--text); }
.px-an-sec { margin-bottom: 14px; }
.px-an-sec:last-child { margin-bottom: 0; }
.px-an-sources {
  margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border-soft);
  font-size: 13px; line-height: 1.8; word-break: break-all;
}
.px-an-sources a { color: var(--accent); text-decoration: none; }
.px-an-sources a:hover { text-decoration: underline; }
.px-an-foot {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border-soft);
}
.px-an-disclaimer { font-size: 12px; color: var(--dim); }
/* 개요 상단 AI 3줄 소개 */
.ov-brief {
  font-size: 15px; line-height: 1.6; color: var(--text);
  margin: 0 0 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border-soft);
}
.ov-brief.loading { color: var(--muted); font-style: italic; }
.ov-brief .ov-brief-tag {
  display: inline-block; margin-left: 4px; font-size: 11px; font-weight: 700; color: var(--accent);
  background: rgba(110,139,255,0.12); border: 1px solid rgba(110,139,255,0.35);
  border-radius: 999px; padding: 1px 7px; vertical-align: middle;
}
/* 1일 이내 공시 NEW 강조 */
.disc-new { background: rgba(110,139,255,0.07); border-radius: var(--radius-sm); }
.disc-new .disc-date { color: var(--accent); font-weight: 600; }
.disc-new a { color: var(--accent); font-weight: 600; }
.disc-new-badge {
  display: inline-block; margin-right: 6px; font-size: 10px; font-weight: 800; color: #fff;
  background: var(--accent); border-radius: 4px; padding: 1px 5px; vertical-align: middle; letter-spacing: .04em;
}
/* 사업내용/경쟁사 웹검색 추가분석 버튼 — 기본 생성물과 구분 (클릭 시 본문을 결과가 덮어씀) */
.deep-wrap { margin-top: 14px; padding-top: 12px; border-top: 1px dashed var(--border-soft); }
/* 주가 전일대비 색상 (상승=빨강 / 하락=파랑) + 증감 */
.px-up { color: var(--neg); }
.px-down { color: var(--accent); }
.px-flat { color: var(--muted); }
.px-change { display: block; font-size: 12px; font-weight: 600; }
/* 리스크 & 체크포인트 (기업 상세 — IR 9·10 컨셉) */
.risk-sub { font-size: 16px; font-weight: 700; color: var(--text); margin: 0 0 12px; }
.chk-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.chk-card { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 14px 16px; }
.chk-title { font-size: 15px; font-weight: 700; color: var(--accent2); margin-bottom: 6px; }
.chk-desc { font-size: 14px; color: var(--muted); line-height: 1.6; }
.oppr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.oppr-box { padding: 14px 16px; border-radius: var(--radius-sm); border: 1px solid var(--border); font-size: 14px; line-height: 1.65; color: var(--text); }
.oppr-box .oppr-h { font-weight: 700; margin-bottom: 8px; font-size: 15px; }
.oppr-box.opp { background: rgba(52,211,153,.07); border-color: rgba(52,211,153,.35); }
.oppr-box.opp .oppr-h { color: #34D399; }
.oppr-box.rsk { background: rgba(248,113,113,.07); border-color: rgba(248,113,113,.35); }
.oppr-box.rsk .oppr-h { color: #F87171; }
@media (max-width: 720px){ .chk-grid, .oppr-grid { grid-template-columns: 1fr; } }
/* 플로팅 '뒤로 가기' — 스크롤 따라다님(고정). 넓은 화면=좌측 거터 알약 / 좁은 화면=좌하단 원형 FAB(본문 겹침 방지) */
.back-float {
  position: fixed; left: 18px; top: 50%; transform: translateY(-50%); z-index: 25;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 15px; border-radius: 999px;
  background: var(--bg-elev2); border: 1px solid var(--border); color: var(--text);
  font-size: 14px; font-weight: 600; text-decoration: none;
  box-shadow: 0 6px 18px rgba(0,0,0,.4);
  transition: background .15s, border-color .15s, color .15s;
}
.back-float:hover { background: var(--accent); border-color: var(--accent); color: #fff; }
.back-float .bf-ico { font-size: 17px; line-height: 1; }
@media (max-width: 1320px) {
  .back-float { left: 16px; top: auto; bottom: 22px; transform: none; padding: 0; width: 48px; height: 48px; justify-content: center; border-radius: 50%; }
  .back-float .bf-text { display: none; }
  .back-float .bf-ico { font-size: 20px; }
}
