/* 종배 레포트 — 모바일 우선, 가독성 중심 다크 테마 */
:root {
  --bg: #0f1216;
  --bg2: #171c22;
  --card: #1c232b;
  --line: #2a333d;
  --fg: #e8edf2;
  --muted: #8a97a6;
  --accent: #4ea1ff;
  --up: #ff5b5b;     /* 한국 관습: 상승=빨강 */
  --down: #3d8bff;   /* 하락=파랑 */
  --gold: #ffcb47;
  --green: #2ec27e;
  --radius: 14px;
  --maxw: 720px;
}
@media (prefers-color-scheme: light) {
  :root { --bg:#f4f6f9; --bg2:#fff; --card:#fff; --line:#e2e8f0; --fg:#11161c; --muted:#5b6776; }
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; background: var(--bg); color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo",
               "Noto Sans KR", Roboto, sans-serif;
  line-height: 1.55; font-size: 16px;
  padding-bottom: env(safe-area-inset-bottom);
}
a { color: var(--accent); text-decoration: none; }

/* ── 상단바 ── */
.topbar {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; background: rgba(15,18,22,.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand { font-weight: 700; font-size: 17px; color: var(--fg); }

/* ── 날짜/탭 ── */
.datebar { max-width: var(--maxw); margin: 14px auto 0; padding: 0 16px;
  display: flex; align-items: center; gap: 10px; }
.date { font-size: 20px; font-weight: 700; letter-spacing: .3px; }
.live-dot { font-size: 11px; color: var(--green); font-weight: 700;
  border: 1px solid var(--green); border-radius: 999px; padding: 1px 7px; animation: pulse 2s infinite; }
@keyframes pulse { 50% { opacity: .45; } }

.tabs { max-width: var(--maxw); margin: 10px auto 0; padding: 0 16px;
  display: flex; gap: 8px; }
.tab { flex: 1; text-align: center; padding: 10px 0; border-radius: 10px;
  background: var(--bg2); border: 1px solid var(--line); color: var(--muted);
  font-weight: 600; font-size: 15px; }
.tab.on { background: var(--accent); color: #06101d; border-color: var(--accent); }
.tab.off { opacity: .4; }

.reload-pill { max-width: var(--maxw); margin: 10px auto 0; padding: 10px 14px;
  background: var(--gold); color: #1a1300; text-align: center; border-radius: 10px;
  font-weight: 700; cursor: pointer; }

/* ── 본문 ── */
.content { max-width: var(--maxw); margin: 0 auto; padding: 8px 16px 40px; }
.hero-head { display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin: 18px 0 6px; }
.hero-title h1 { font-size: 19px; margin: 0; }
.hero-title .muted { font-size: 13px; }
.muted { color: var(--muted); }
.sec { font-size: 14px; color: var(--muted); margin: 22px 0 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px; }
.count { color: var(--fg); background: var(--bg2); border-radius: 999px;
  padding: 1px 9px; font-size: 13px; margin-left: 4px; }
.empty { color: var(--muted); padding: 24px 0; }

/* 국면 배너 */
.regime { font-weight: 700; font-size: 13px; padding: 6px 12px; border-radius: 999px;
  white-space: nowrap; }
.regime.bull { background: rgba(46,194,126,.16); color: var(--green); }
.regime.bear { background: rgba(255,91,91,.16); color: var(--up); }

/* 테마 chips */
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chip { background: var(--bg2); border: 1px solid var(--line); border-radius: 999px;
  padding: 6px 13px; font-size: 14px; }
.chip b { color: var(--gold); }
/* 주도테마 구성종목 popover — hover(데스크탑) / long-press·tap(모바일) / focus(키보드) */
.chip.has-pop { position: relative; cursor: pointer; user-select: none;
  -webkit-user-select: none; -webkit-touch-callout: none; }
.chip.has-pop::after { content: "›"; color: var(--muted); margin-left: 5px;
  font-size: 12px; transform: rotate(90deg); display: inline-block; }
.chip-pop { position: absolute; left: 0; top: calc(100% + 6px); z-index: 30;
  display: none; min-width: 130px; max-width: 240px; padding: 7px 9px;
  background: var(--card); border: 1px solid var(--gold); border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0,0,0,.45); white-space: normal; }
.chip-pop-item { display: block; font-size: 13px; line-height: 1.7; color: var(--fg); }
.chip-pop-item + .chip-pop-item { border-top: 1px solid var(--line); }
/* hover(데스크탑) / long-press(.pop-open, 모바일) 만 popover. focus 는 제외 —
   클릭/탭은 아래 '후보 강조' 토글 전용이라 둘이 안 섞이게. */
.chip.has-pop:hover .chip-pop,
.chip.has-pop.pop-open .chip-pop { display: block; }

/* 주도테마 클릭/탭 → 종배 후보 강조 (theme_highlight.js) */
.chip[data-theme] { cursor: pointer; user-select: none; -webkit-user-select: none; }
.chip.theme-active { background: var(--theme-color); color: #16191e;
  border-color: rgba(0,0,0,.28); font-weight: 600; }
.chip.theme-active b { color: #7a5500; }
.chip.theme-active::after { color: rgba(0,0,0,.45); }

/* ── 후보 카드 ── */
.card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 14px 15px; margin-bottom: 13px; transition: background .12s ease; }
/* 주도테마 강조 — 연한 배경(인라인) 위에서 글씨가 보이도록 카드 스코프 변수를
   어두운 값으로 재정의. 빨강/파랑 등락은 진한 빨강/파랑으로 유지(가독). */
.card.theme-hl {
  --fg: #16191e; --muted: #56616f; --line: rgba(0,0,0,.16);
  --up: #c0152f; --down: #14439e; --gold: #8a6300; --green: #1c7a4d; --accent: #1d5fc0;
  --bg2: rgba(255,255,255,.5);
  color: #16191e; border-color: rgba(0,0,0,.16);
}
.card.theme-hl .badge.lim { background: #c0152f; color: #fff; }
.card.top3 { border-color: var(--gold); box-shadow: 0 0 0 1px rgba(255,203,71,.25); }
.card-top { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.card-top .rk { color: var(--muted); font-weight: 700; }
.card-top .nm { font-size: 18px; font-weight: 700; }
.card-top .cd { color: var(--muted); font-size: 13px; }
.card-top .ret { margin-left: auto; font-size: 18px; font-weight: 800; }
.card-sub { margin-top: 6px; font-size: 14px; color: var(--muted); }
.card-sub b { color: var(--fg); }
.card-sub em { font-style: normal; }

/* 상세 섹션 */
.dsec { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .4px;
  margin: 16px 0 6px; padding-bottom: 4px; border-bottom: 1px solid var(--line); }
.dsec .warn { text-transform: none; letter-spacing: 0; }
.dnote { color: var(--muted); font-size: 13px; margin: 4px 0; }
.mtx { border-collapse: collapse; width: 100%; font-size: 13px; margin: 4px 0; }
.mtx th, .mtx td { border: 1px solid var(--line); padding: 5px 6px; text-align: center; }
.mtx th { color: var(--muted); font-weight: 600; }
.mtx td small { display: block; color: var(--muted); font-size: 10px; }
.badge { font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 6px; }
.badge.top { background: var(--gold); color: #1a1300; }
.badge.lim { background: var(--up); color: #fff; }

.card-themes { display: flex; flex-wrap: wrap; gap: 6px; margin: 9px 0 2px; }
.tchip { font-size: 12px; color: var(--muted); background: var(--bg2);
  border-radius: 6px; padding: 2px 8px; }
.tchip.more { color: var(--accent); }

.card-price { display: flex; align-items: baseline; gap: 10px; margin: 10px 0; }
.card-price .ret { font-size: 22px; font-weight: 800; }
.ret.up { color: var(--up); } .ret.down { color: var(--down); }
.card-price .px { font-size: 16px; color: var(--fg); }

.kv { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 12px; margin: 8px 0; }
.kv .k, .gap .k, .sz .k, .drow .k { color: var(--muted); font-size: 12px; }
.kv .v { font-weight: 600; } .kv em, .gap .gn { color: var(--muted); font-style: normal; font-size: 12px; }

.gap { display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  background: var(--bg2); border-radius: 10px; padding: 9px 12px; margin: 10px 0; }
.gap .gp { font-size: 18px; font-weight: 800; color: var(--green); }
.gap .ge { font-weight: 600; }
.gap .warn { color: var(--gold); font-size: 11px; border: 1px solid var(--gold);
  border-radius: 6px; padding: 0 6px; }

.sizing { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 10px; }
.sz { background: var(--bg2); border-radius: 10px; padding: 9px 6px; text-align: center; }
.sz .v { display: block; font-weight: 700; margin-top: 2px; }
.sz .v.big { font-size: 18px; color: var(--gold); }

details.more { margin-top: 10px; }
details.more summary, details.rawreport summary {
  cursor: pointer; color: var(--accent); font-size: 14px; font-weight: 600; }
/* 상세 보기 내용 — 흰 배경 + 어두운 글씨 (다크 본문 눈부심 완화). 변수 재정의로 일괄 가독.
   요약/하이라이트(.theme-hl)와 무관하게 상세 영역만 항상 흰바탕. */
.detail {
  margin-top: 8px; background: #fff; color: #16191e;
  --fg: #16191e; --muted: #586472; --line: #e3e8ef; --bg2: #eef2f7;
  --up: #c0152f; --down: #14439e; --gold: #8a6300; --green: #1c7a4d; --accent: #1d5fc0;
  border-radius: 10px; padding: 6px 12px 12px;
}
.drow { display: flex; justify-content: space-between; gap: 12px;
  padding: 5px 0; border-top: 1px solid var(--line); font-size: 14px; }
.trend i { font-style: normal; margin-left: 8px; color: var(--muted); }

/* 원문 마크다운 */
details.rawreport { margin-top: 26px; border-top: 1px solid var(--line); padding-top: 16px; }
.md { font-size: 15px; overflow-x: auto; }
.md h1, .md h2, .md h3 { line-height: 1.3; margin: 18px 0 8px; }
.md h1 { font-size: 19px; } .md h2 { font-size: 17px; } .md h3 { font-size: 15px; }
.md table { border-collapse: collapse; width: 100%; font-size: 13px; margin: 12px 0; }
.md th, .md td { border: 1px solid var(--line); padding: 6px 8px; text-align: right; }
.md th:first-child, .md td:first-child { text-align: left; }
.md pre { background: var(--bg2); padding: 12px; border-radius: 10px; overflow-x: auto;
  font-size: 12px; line-height: 1.4; }
.md code { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.md pre code { white-space: pre; }

/* 보관함 */
.archive { list-style: none; padding: 0; margin: 12px 0; }
.archive li { display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 13px 4px; border-bottom: 1px solid var(--line); }
.adate { font-weight: 700; font-size: 16px; }
.alabels { display: flex; gap: 8px; }
.albl { font-size: 13px; background: var(--bg2); border: 1px solid var(--line);
  border-radius: 8px; padding: 5px 11px; }

/* 로그인 (비번 한 칸) */
.login { max-width: 360px; margin: 14vh auto 0; text-align: center; }
.login h1 { font-size: 24px; margin: 0 0 4px; }
.login form { display: flex; flex-direction: column; gap: 12px; margin-top: 22px; }
.login input[type=password] {
  font-size: 17px; padding: 14px 16px; border-radius: 12px;
  border: 1px solid var(--line); background: var(--bg2); color: var(--fg);
}
.login input[type=password]:focus { outline: none; border-color: var(--accent); }
.login button {
  font-size: 16px; font-weight: 700; padding: 13px; border: none; border-radius: 12px;
  background: var(--accent); color: #06101d; cursor: pointer;
}
.login-err { color: var(--up); font-size: 14px; margin: 4px 0 0; }

/* 푸터 */
.foot { max-width: var(--maxw); margin: 0 auto; padding: 20px 16px 40px;
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--line); font-size: 13px; }
.foot .muted { font-size: 12px; }

@media (min-width: 560px) {
  .hero-title h1 { font-size: 22px; }
}
