:root{--bg:#f3f6fb;--panel:#fff;--text:#0f172a;--muted:#64748b;--line:#e2e8f0;--primary:#2563eb}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,'Noto Sans KR',sans-serif}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;background:#fff;border-bottom:1px solid var(--line)}
.brand{display:flex;gap:12px;align-items:center}.logo{width:38px;height:38px;border-radius:10px;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:800}
.title{font-size:20px;font-weight:800}.subtitle,.meta,.small-note{color:var(--muted);font-size:13px;line-height:1.5}.status-pill{display:inline-flex;padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:#fff}
.page{max-width:1500px;margin:0 auto;padding:20px;display:grid;grid-template-columns:300px minmax(0,1fr) 360px;gap:16px;align-items:start}
.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.04)}
.left-panel,.right-panel{padding:16px}.right-panel{position:sticky;top:16px;max-height:calc(100vh - 32px);overflow:auto}.panel-title{margin:0 0 16px;font-size:18px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;font-size:14px;font-weight:700}
.field input,.field select,.toolbar input,textarea{width:100%;padding:11px 12px;border:1px solid #dbe2ea;border-radius:12px;background:#fff}
.stack-col{display:flex;flex-direction:column;gap:10px}.date-grid{display:grid;grid-template-columns:132px 132px;gap:10px;justify-content:start}.date-grid .field{margin-bottom:0}
button{padding:10px 12px;border:1px solid #dbe2ea;border-radius:12px;background:#fff;cursor:pointer}button.primary{background:var(--primary);border-color:var(--primary);color:#fff}button.ghost{background:#fff;color:#111827}button.small{padding:8px 10px;font-size:12px}button.large{padding:13px 14px;font-weight:700}
.period-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.period-btn.is-active{background:#111827;color:#fff;border-color:#111827}
.center-panel{display:flex;flex-direction:column;gap:12px;min-width:0}.hero-card{padding:16px;background:#5e96c9;color:#fff}.hero-title{font-size:42px;font-weight:300;line-height:1.2}.hero-sub{margin-top:8px;font-size:14px;opacity:.9}.chart-placeholder{margin-top:10px;border:1px dashed rgba(255,255,255,.6);border-radius:12px;padding:14px}
.market-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:8px}.market-item{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px}.market-value{font-size:34px;font-weight:700;color:#0c3b79}
.analysis-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.analysis-card{background:#fff;border:1px dashed #cbd5e1;border-radius:14px;padding:14px}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.kpi-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px}.kpi-label{font-size:12px;color:var(--muted);margin-bottom:10px}.kpi-value{font-size:28px;font-weight:800}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 16px 0 16px}.section-head h2{margin:0;font-size:18px}
.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.checkbox-row{display:flex;gap:6px;align-items:center;color:var(--muted);font-size:13px}
.article-list,.candidate-list{display:flex;flex-direction:column;gap:12px;padding:16px}.article-card,.candidate-card{border:1px solid var(--line);border-radius:14px;padding:14px;background:#fff}
.article-card.is-selected{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.chips,.row,.actions,.candidate-top{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.chip{padding:4px 8px;border-radius:999px;background:#f1f5f9;font-size:12px}.article-title,.candidate-title{font-size:17px;line-height:1.45;margin:8px 0;font-weight:800}.article-desc,.candidate-sub{color:var(--muted);font-size:13px;line-height:1.6}
.loading{margin:0 16px 16px;padding:12px;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;background:#f8fafc}.hidden{display:none!important}.empty{padding:18px;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;background:#f8fafc}
.sticky-head{position:sticky;top:0;background:#fff;z-index:2;padding-bottom:12px}.candidate-sort-row{display:flex;gap:8px;padding:0 16px 4px}.pinned-badge{display:inline-flex;background:#fff7ed;color:#9a3412;border:1px solid #fdba74;padding:4px 8px;border-radius:999px;font-size:12px}
@media (max-width:1200px){.page{grid-template-columns:280px minmax(0,1fr)}.right-panel{grid-column:1 / -1;position:static;max-height:none}}
@media (max-width:860px){.page{grid-template-columns:1fr}.kpi-grid,.analysis-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:560px){.kpi-grid,.period-row,.date-grid,.analysis-grid,.market-strip{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.hero-title{font-size:30px}}
