/* 나라장터·지원사업 대시보드 — 검은 계열 다크 베이스 + 어댑터즈(테트리코드 BI) 오렌지 강조.
   배경은 다크 슬레이트(#0e1116 계열), 강조는 TETRICODE Orange #FF7F40 · 보조 Beige #F08848.
   긴급도(마감)·분류 색은 의미 신호라 별도 팔레트 유지. 단일 출처: ClaudeMd/content/cardnews/tetricode/DESIGN.md */
:root {
  --bg: #0e1116;
  --panel: #161b22;
  --panel-2: #1c2230;
  --line: #2a3140;
  --line-soft: #222936;
  --fg: #e6edf3;
  --muted: #9aa7b8;
  --muted-dim: #6b7888;
  --accent: #ff7f40;        /* TETRICODE Orange */
  --accent-dim: #9a4e26;
  --beige: #f08848;
  --on-accent: #2a0f0c;
  --accent-text: #ffffff;
  /* 긴급도 신호색 */
  --critical: #ff5d5d;      /* expired / today */
  --high: #ff9f43;          /* d3 */
  --medium: #ffd34e;        /* d7 */
  --ok: #46d39a;            /* d14 이상·여유 */
  --info: #5fb3ff;          /* d30 */
  /* 분류 팔레트 (도넛/배지) — 신호색 외, 분류용 무채-보조색 */
  --c1: #ff7f40; --c2: #5fb3ff; --c3: #b487ff; --c4: #46d39a; --c5: #ffd34e; --c6: #ff5d8a; --c7: #6fd9d9;
  --radius: 12px;
  --radius-sm: 8px;
  --gap: 16px;
  font-variant-numeric: tabular-nums;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; max-width: 100%; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
#view, main, .panel, .kpis, .filterbar { max-width: 100%; }
body {
  background: var(--bg); color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Pretendard", "Apple SD Gothic Neo", "Segoe UI", Roboto, sans-serif;
  font-size: 15px; line-height: 1.6;
}
a { color: var(--accent-text); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- 상단 바 ---- */
.topbar {
  position: sticky; top: 0; z-index: 20;
  background: linear-gradient(180deg, #11161e, #0e1116);
  border-bottom: 1px solid var(--line); padding: 14px 22px;
}
.bar-inner { max-width: 1320px; margin: 0 auto; width: 100%; display: flex; flex-wrap: wrap; align-items: center; gap: 12px 20px; }
.topbar h1 { font-size: 18px; margin: 0; font-weight: 700; letter-spacing: -0.2px; }
.local-badge {
  font-size: 11px; font-weight: 600; color: var(--high);
  border: 1px solid var(--high); border-radius: 999px; padding: 2px 9px; margin-left: 8px; vertical-align: middle;
}
.topbar .sub { margin: 2px 0 0; font-size: 12.5px; color: var(--muted-dim); }

/* ---- 탭 ---- */
.tabs { display: flex; gap: 6px; margin-left: auto; flex-wrap: wrap; }
.tab {
  background: var(--panel); color: var(--muted); border: 1px solid var(--line);
  border-radius: 999px; padding: 6px 16px; font-size: 13.5px; font-weight: 600; cursor: pointer; transition: .12s;
}
.tab:hover { color: var(--fg); border-color: var(--accent-dim); }
.tab.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.tab.empty { opacity: .5; }
.tab .tcount { font-size: 11px; opacity: .7; margin-left: 4px; }
.tab.active .tcount { opacity: .85; }

/* ---- 메인 ---- */
main { padding: 20px 22px 60px; max-width: 1320px; margin: 0 auto; }

/* ---- 필터 바 ---- */
.filterbar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 12px 16px; margin-bottom: 18px;
}
@media (min-width: 561px) {
  .filterbar { position: sticky; top: 80px; z-index: 15; box-shadow: 0 6px 16px -10px rgba(0,0,0,.6); }
}
.filterbar label { font-size: 12px; color: var(--muted-dim); margin-right: 4px; white-space: nowrap; }
.fgroup { display: flex; align-items: center; gap: 6px; }
.resetbtn { background: transparent; color: var(--muted); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 6px 12px; font-size: 12.5px; cursor: pointer; font-family: inherit; }
.resetbtn:hover { color: var(--fg); border-color: var(--accent-dim); }
.fcount { font-size: 12px; white-space: nowrap; }
select, .pseg button, .navbtn, input[type="text"], input[type="search"], input[type="number"] {
  background: var(--panel-2); color: var(--fg);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 6px 10px; font-size: 13.5px; font-family: inherit;
}
select { cursor: pointer; }
.pseg { display: inline-flex; border: 1px solid var(--line); border-radius: var(--radius-sm); overflow: hidden; flex-shrink: 0; }
.pseg button { border: 0; border-right: 1px solid var(--line); border-radius: 0; cursor: pointer; color: var(--muted); padding: 6px 13px; }
.pseg button:last-child { border-right: 0; }
.pseg button.active { background: var(--accent); color: var(--on-accent); font-weight: 700; }
.navbtn { cursor: pointer; padding: 6px 11px; }
.navbtn:disabled { opacity: .35; cursor: default; }
.spacer { flex: 1; }

/* ---- KPI ---- */
.kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--gap); margin-bottom: 20px; }
.kpi { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 16px; position: relative; }
.kpi .label { font-size: 12px; color: var(--muted-dim); }
.kpi .val { font-size: 26px; font-weight: 800; letter-spacing: -0.5px; margin-top: 2px; }
.kpi .sub { font-size: 12px; color: var(--muted); margin-top: 2px; }
.kpi.warn .val { color: var(--high); }
.kpi.bad .val { color: var(--critical); }
.kpi.good .val { color: var(--ok); }
.kpi.clickable { cursor: pointer; }
.kpi.clickable:hover { border-color: var(--high); transform: translateY(-1px); }
.dlt { font-size: 13px; font-weight: 700; margin-left: 4px; vertical-align: 2px; }
.dlt.up { color: var(--ok); } .dlt.down { color: var(--critical); } .dlt.flat { color: var(--muted-dim); }

/* ---- 패널 ---- */
.panel {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 18px 18px 20px; margin-bottom: 20px;
}
.panel h2 { font-size: 15px; margin: 0 0 14px; padding-left: 11px; position: relative; font-weight: 700; }
.panel h2::before {
  content: ""; position: absolute; left: 0; top: 2px; bottom: 2px; width: 4px;
  background: var(--accent); border-radius: 2px;
}
.panel h2 .cnt { color: var(--muted-dim); font-weight: 500; font-size: 13px; margin-left: 6px; }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.grid3 { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: var(--gap); }
@media (max-width: 980px) { .grid2, .grid3 { grid-template-columns: 1fr; } }

/* ---- 우선순위 매트릭스 (산점도) ---- */
.scatter {
  position: relative; width: 100%; height: 360px;
  background:
    linear-gradient(to right, transparent 0, transparent 49.5%, rgba(255,255,255,.08) 49.5%, rgba(255,255,255,.08) 50.5%, transparent 50.5%),
    linear-gradient(to top, transparent 0, transparent 49.5%, rgba(255,255,255,.08) 49.5%, rgba(255,255,255,.08) 50.5%, transparent 50.5%),
    var(--panel-2);
  border: 1px solid var(--line-soft); border-radius: var(--radius-sm);
  padding: 16px 20px 28px 56px;
}
.scatter .axis-x { position: absolute; left: 56px; right: 20px; bottom: 6px; color: var(--muted-dim); font-size: 11px; display: flex; justify-content: space-between; }
.scatter .axis-y { position: absolute; top: 16px; bottom: 28px; left: 8px; color: var(--muted-dim); font-size: 11px; display: flex; flex-direction: column; justify-content: space-between; align-items: flex-end; }
.scatter .axis-lb { position: absolute; color: var(--muted); font-size: 11.5px; font-weight: 600; }
.scatter .axis-lb.x { bottom: 6px; right: 24px; }
.scatter .axis-lb.y { top: 12px; left: 8px; writing-mode: vertical-rl; transform: rotate(180deg); }
.scatter .qzone { position: absolute; font-size: 10px; color: var(--muted-dim); pointer-events: none; padding: 2px 6px; }
.scatter .qzone.tr { top: 22px; right: 24px; color: var(--accent); }
.scatter .qzone.tl { top: 22px; left: 60px; color: var(--info); }
.scatter .qzone.br { bottom: 30px; right: 24px; color: var(--muted); }
.scatter .qzone.bl { bottom: 30px; left: 60px; color: var(--muted-dim); }
.scatter .dot {
  position: absolute; width: 10px; height: 10px; border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.6); cursor: pointer;
  transition: transform .1s, box-shadow .1s; transform: translate(-50%, 50%);
}
.scatter .dot:hover { transform: translate(-50%, 50%) scale(2); box-shadow: 0 0 0 3px rgba(255,127,64,.3); z-index: 5; }
.scatter .dot.expired { background: var(--critical); }
.scatter .dot.today, .scatter .dot.d3 { background: var(--high); }
.scatter .dot.d7 { background: var(--medium); }
.scatter .dot.d14 { background: var(--info); }
.scatter .dot.d30, .scatter .dot.far { background: var(--ok); }
.scatter .dot.none { background: var(--muted-dim); border-color: var(--muted); }
.scatter-legend { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 16px; margin-top: 8px; font-size: 12px; color: var(--muted); }
.scatter-legend-it { display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.scatter-legend-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; border: 1px solid rgba(255,255,255,.4); }
.urg-expired { background: var(--critical); } .urg-today, .urg-d3 { background: var(--high); }
.urg-d7 { background: var(--medium); } .urg-d14 { background: var(--info); } .urg-d30, .urg-far { background: var(--ok); }
.urg-none { background: var(--muted-dim); }

/* ---- 마감 캘린더 히트맵 (30일) ---- */
.cal { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; margin-top: 8px; }
.calhd { font-size: 11px; color: var(--muted-dim); text-align: center; padding: 3px 0; }
.calhd.sat { color: var(--info); } .calhd.sun { color: var(--critical); }
.calcell { background: var(--panel-2); border: 1px solid var(--line-soft); border-radius: 6px; padding: 5px 6px; min-height: 56px; position: relative; cursor: pointer; transition: .1s; }
.calcell:hover { border-color: var(--accent-dim); background: rgba(255,127,64,.08); }
.calcell.empty { opacity: .35; cursor: default; }
.calcell.empty:hover { background: var(--panel-2); border-color: var(--line-soft); }
.calcell.today { border-color: var(--accent); background: rgba(255,127,64,.12); }
.cald { font-size: 11px; color: var(--muted); }
.calcell.today .cald { color: var(--accent-text); font-weight: 700; }
.calcell.sat .cald { color: var(--info); } .calcell.sun .cald { color: var(--critical); }
.caln { font-size: 18px; font-weight: 800; color: var(--fg); margin-top: 2px; }
.calcell.has-n.h1 { background: rgba(70,211,154,.10); }
.calcell.has-n.h2 { background: rgba(95,179,255,.13); }
.calcell.has-n.h3 { background: rgba(255,159,67,.18); }
.calcell.has-n.h4 { background: rgba(255,93,93,.22); }
.calcell.has-n .caln { color: var(--accent-text); }

/* ---- 도넛 ---- */
.donutwrap { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.donutsvg { flex: 0 0 auto; }
.donutsvg circle.track { fill: none; stroke: var(--panel-2); stroke-width: 18; }
.donutsvg circle.seg { fill: none; stroke-width: 18; transition: stroke-width .12s; cursor: pointer; }
.donutsvg circle.seg:hover { stroke-width: 22; }
.donut-center { text-anchor: middle; }
.donut-center .dc-n { font-size: 22px; font-weight: 800; fill: var(--fg); }
.donut-center .dc-lb { font-size: 10px; fill: var(--muted-dim); }
.donutlegend { flex: 1; display: flex; flex-direction: column; gap: 5px; min-width: 180px; }
.dlrow { display: grid; grid-template-columns: 14px 1fr 44px; align-items: center; gap: 8px; font-size: 12.5px; cursor: pointer; padding: 3px 4px; border-radius: 5px; }
.dlrow:hover { background: rgba(255,127,64,.08); }
.dldot { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }
.dlname { color: var(--fg); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dlnum { color: var(--muted-dim); text-align: right; font-size: 11.5px; }
.dlnum b { color: var(--fg); font-weight: 700; font-size: 12.5px; }

/* ---- 막대 (기관 Top·일별 추이 등 공용) ---- */
.bars { display: flex; flex-direction: column; gap: 5px; }
.brow { display: grid; grid-template-columns: 1fr 60px; align-items: center; gap: 8px; font-size: 12.5px; padding: 3px 4px; border-radius: 5px; cursor: pointer; }
.brow:hover { background: rgba(255,127,64,.08); }
.brow .blname { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--fg); position: relative; padding: 6px 8px; }
.brow .blfill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--accent-dim); opacity: .35; border-radius: 4px; z-index: 0; }
.brow .blname span { position: relative; z-index: 1; }
.brow .blnum { color: var(--muted); text-align: right; font-variant-numeric: tabular-nums; }
.brow .blnum b { color: var(--fg); font-weight: 700; }

/* ---- 추이(일별 막대) ---- */
.trend { display: flex; align-items: flex-end; gap: 4px; height: 130px; padding-top: 10px; position: relative; }
.tbar-wrap { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: flex-end; height: 100%; min-width: 0; }
.tbar { width: 70%; background: var(--accent-dim); border-radius: 4px 4px 0 0; min-height: 2px; transition: .12s; }
.tbar-wrap:hover .tbar { background: var(--accent); }
.tbar-wrap.peak .tbar { background: var(--ok); }
.tbar-lbl { font-size: 10px; color: var(--muted-dim); margin-top: 5px; white-space: nowrap; }
.tbar-val { font-size: 10px; color: var(--muted); margin-bottom: 3px; }

/* ---- 키워드 클라우드 ---- */
.kwcloud { display: flex; flex-wrap: wrap; gap: 5px 12px; align-items: baseline; }
.kw { background: transparent; border: 0; color: var(--accent-text); cursor: pointer; font-family: inherit; font-weight: 700; line-height: 1.25; padding: 1px 2px; }
.kw:hover { text-decoration: underline; }
.kw.on { color: var(--ok); text-decoration: underline; }
.kwn { font-size: 10px; color: var(--muted-dim); font-weight: 500; margin-left: 2px; vertical-align: super; }

/* ---- 테이블 ---- */
table { width: 100%; border-collapse: collapse; font-size: 13px; }
th, td { padding: 7px 10px; text-align: left; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
th { color: var(--muted-dim); text-transform: uppercase; font-size: 11px; letter-spacing: .4px; font-weight: 600; cursor: pointer; user-select: none; white-space: nowrap; }
th.sortable:hover { color: var(--fg); }
th .sortarrow { color: var(--accent); margin-left: 3px; font-size: 10px; }
tbody tr:nth-child(even) { background: rgba(255,255,255,.018); }
tbody tr:hover { background: rgba(255,127,64,.07); }
td.num { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }
.muted { color: var(--muted-dim); }
.wraptext { max-width: 460px; white-space: pre-wrap; word-break: break-word; }
.tscroll { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.tscroll table { min-width: 880px; }

/* ---- 입찰 행 ---- */
.bid-row { cursor: pointer; }
.bid-title { font-weight: 600; color: var(--fg); }
.bid-meta { font-size: 11.5px; color: var(--muted-dim); margin-top: 2px; }
.bid-kw { display: inline-block; font-size: 10.5px; color: var(--accent-text); background: rgba(255,127,64,.10); border-radius: 4px; padding: 1px 6px; margin-right: 3px; }
.bid-row.open { background: rgba(255,127,64,.08); }
.bid-row .lowmore { font-size: 11px; color: var(--muted-dim); white-space: nowrap; }
.bid-row:hover .lowmore { color: var(--accent-text); }
.bid-detail > td { padding: 0 10px 12px; background: rgba(255,127,64,.04); }
.bd-box { display: flex; flex-direction: column; gap: 6px; padding: 12px 14px; border: 1px solid var(--line-soft); border-radius: var(--radius-sm); background: var(--panel-2); }
.bd-row { display: grid; grid-template-columns: 130px 1fr; gap: 12px; font-size: 13px; line-height: 1.6; }
.bd-k { color: var(--muted-dim); font-weight: 600; }
.bd-v { color: var(--fg); white-space: pre-wrap; word-break: break-word; }
.bd-v a { color: var(--accent-text); text-decoration: underline; }
@media (max-width: 560px) { .bd-row { grid-template-columns: 1fr; gap: 2px; } }

/* ---- 긴급도 배지 ---- */
.ubadge { display: inline-block; min-width: 56px; text-align: center; border-radius: 5px; padding: 1px 8px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.ub-expired { background: rgba(120,120,120,.18); color: var(--muted); border: 1px solid var(--muted-dim); }
.ub-today { background: var(--critical); color: #fff; }
.ub-d3 { background: var(--high); color: var(--on-accent); }
.ub-d7 { background: var(--medium); color: var(--on-accent); }
.ub-d14 { background: var(--info); color: #07223a; }
.ub-d30, .ub-far { background: var(--ok); color: #062518; }
.ub-none { background: var(--panel-2); color: var(--muted-dim); border: 1px solid var(--line); }

/* ---- 관련성 점수 칩 ---- */
.relpill { display: inline-block; min-width: 38px; text-align: center; border-radius: 5px; padding: 1px 7px; font-weight: 700; font-size: 12px; color: var(--on-accent); }
.rel-hi { background: var(--ok); } .rel-mid { background: var(--medium); } .rel-lo { background: var(--high); } .rel-na { background: var(--panel-2); color: var(--muted); border: 1px solid var(--line); }

/* ---- 상태 칩(확인/참여) ---- */
.schip {
  background: var(--panel-2); color: var(--muted); border: 1px solid var(--line);
  border-radius: 999px; padding: 4px 11px; font-size: 12.5px; font-weight: 600; cursor: pointer; font-family: inherit;
}
.schip:hover { color: var(--fg); border-color: var(--accent-dim); }
.schip .fcount { font-size: 11px; opacity: .7; margin-left: 3px; }
.schip.active { background: var(--accent); color: var(--on-accent); border-color: var(--accent); }
.schip.s-miss.active { background: var(--critical); color: #fff; border-color: var(--critical); }
.schip.s-done.active { background: var(--ok); color: var(--on-accent); border-color: var(--ok); }

/* ---- 도움말 ? 배지 + 툴팁 ---- */
.help {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; margin-left: 6px; vertical-align: middle;
  border-radius: 50%; border: 1px solid var(--line);
  background: var(--panel-2); color: var(--muted);
  font-size: 11px; font-weight: 700; line-height: 1; cursor: help;
  position: relative; user-select: none; flex: 0 0 auto;
}
.help:hover, .help:focus { color: var(--on-accent); background: var(--accent); border-color: var(--accent); outline: none; }
.help::after {
  content: attr(data-tip);
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  width: max-content; max-width: 320px; white-space: normal;
  background: #0a0e14; color: var(--fg); border: 1px solid var(--accent-dim);
  border-radius: 8px; padding: 9px 12px; font-size: 12.5px; font-weight: 400;
  line-height: 1.6; text-align: left; letter-spacing: 0;
  box-shadow: 0 10px 28px -8px rgba(0,0,0,.7); z-index: 60;
  opacity: 0; visibility: hidden; transition: opacity .12s, transform .12s; pointer-events: none;
}
.help::before {
  content: ""; position: absolute; top: calc(100% + 2px); left: 50%;
  transform: translateX(-50%); border: 6px solid transparent;
  border-bottom-color: var(--accent-dim); z-index: 61; opacity: 0; visibility: hidden; transition: opacity .12s;
}
.help:hover::after, .help:focus::after, .help:hover::before, .help:focus::before { opacity: 1; visibility: visible; }
.panel h2 .help::after { left: 0; transform: none; }
.panel h2 .help::before { left: 14px; }

/* ---- 색상 범례 ---- */
.legend {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px 16px;
  margin: -6px 0 20px; padding: 9px 14px;
  background: var(--panel); border: 1px solid var(--line-soft); border-radius: var(--radius-sm);
  font-size: 12px; color: var(--muted);
}
.legend-lb { color: var(--muted-dim); font-weight: 600; display: inline-flex; align-items: center; }
.legend-it { display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.legend-dot { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }

/* ---- 오늘 볼 것 콜아웃 ---- */
.callout {
  display: flex; align-items: flex-start; gap: 12px;
  border-radius: var(--radius); padding: 13px 16px; margin-bottom: 18px;
  border: 1px solid var(--line); background: var(--panel);
}
.callout.bad { border-color: rgba(255,93,93,.5); background: linear-gradient(180deg, rgba(255,93,93,.1), var(--panel)); }
.callout.warn { border-color: rgba(255,159,67,.5); background: linear-gradient(180deg, rgba(255,159,67,.09), var(--panel)); }
.callout.ok { border-color: rgba(70,211,154,.45); background: linear-gradient(180deg, rgba(70,211,154,.08), var(--panel)); }
.callout-tag {
  flex: 0 0 auto; font-size: 11.5px; font-weight: 800; letter-spacing: .3px;
  padding: 3px 10px; border-radius: 999px; color: var(--on-accent); white-space: nowrap; margin-top: 1px;
}
.callout.bad .callout-tag { background: var(--critical); color: #fff; }
.callout.warn .callout-tag { background: var(--high); }
.callout.ok .callout-tag { background: var(--ok); }
.callout-msg { font-size: 14px; line-height: 1.6; }
.callout-msg b { color: var(--fg); }

/* ---- 필터 칩 적용 표시 ---- */
.afbar { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin: 4px 0 12px; }
.afbar-lb { font-size: 11.5px; color: var(--muted-dim); margin-right: 2px; }
.afchip {
  background: rgba(255,127,64,.12); color: var(--accent-text); border: 1px solid var(--accent-dim);
  border-radius: 999px; padding: 3px 10px; font-size: 12px; font-weight: 600; cursor: pointer; font-family: inherit;
}
.afchip:hover { background: rgba(255,93,93,.14); color: var(--critical); border-color: var(--critical); }
.afclear { background: transparent; color: var(--muted-dim); border: 0; cursor: pointer; font-size: 12px; font-family: inherit; text-decoration: underline; padding: 3px 4px; }
.afclear:hover { color: var(--fg); }

/* ---- 더 보기 / 검색 ---- */
.morebtn { display: block; width: 100%; margin-top: 10px; padding: 9px; background: var(--panel-2); color: var(--fg); border: 1px solid var(--line); border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; cursor: pointer; font-family: inherit; }
.morebtn:hover { border-color: var(--accent-dim); color: var(--accent-text); }
.search { width: 100%; max-width: 320px; }
input[type=search] { width: 100%; padding: 7px 11px; }

/* ---- 빈 상태 ---- */
.nodata { border: 1px dashed var(--line); border-radius: var(--radius-sm); padding: 22px; text-align: center; color: var(--muted-dim); font-size: 13.5px; }
.notice { background: rgba(255,159,67,.08); border: 1px solid rgba(255,159,67,.3); color: var(--high); border-radius: var(--radius-sm); padding: 10px 14px; font-size: 13px; margin-bottom: 16px; }
.emptybig { text-align: center; padding: 60px 24px; border: 1px dashed var(--line); border-radius: var(--radius); background: var(--panel); }
.emptybig-ico { width: 56px; height: 56px; line-height: 52px; margin: 0 auto 16px; border-radius: 50%; border: 2px solid var(--line); color: var(--muted-dim); font-size: 30px; }
.emptybig-t { font-size: 17px; font-weight: 700; margin-bottom: 8px; }
.emptybig-d { font-size: 13.5px; color: var(--muted); line-height: 1.7; margin-bottom: 18px; }

/* ---- 푸터 ---- */
.foot { color: var(--muted-dim); font-size: 12px; padding: 18px 22px 40px; border-top: 1px solid var(--line); margin-top: 30px; }
.foot-inner { max-width: 1320px; margin: 0 auto; }
.foot code { background: var(--panel-2); padding: 1px 6px; border-radius: 4px; }
.foot a { color: var(--accent-text); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---- 모바일 ---- */
@media (max-width: 560px) {
  .topbar { padding: 12px 16px; }
  .bar-inner { flex-direction: column; align-items: stretch; gap: 10px; }
  .topbar h1 { font-size: 16px; }
  .tabs { margin-left: 0; }
  .tab { padding: 6px 13px; }
  main { padding: 16px 14px 50px; }
  .panel { padding: 14px 13px 16px; }
  .filterbar { padding: 10px 12px; flex-direction: column; align-items: stretch; gap: 9px; }
  .fgroup { width: 100%; min-width: 0; flex-wrap: wrap; }
  .fgroup select { flex: 1 1 0; min-width: 0; }
  .fgroup .pseg { flex: 1 1 0; min-width: 0; display: grid; grid-auto-flow: column; grid-auto-columns: 1fr; }
  .fgroup .pseg button { min-width: 0; text-align: center; padding: 6px 2px; border-right: 1px solid var(--line); }
  .filterbar .spacer { display: none; }
  .fcount { align-self: flex-end; }
  .kpi .val { font-size: 22px; }
  .scatter { height: 280px; padding: 12px 16px 26px 48px; }
  .cal { grid-template-columns: repeat(7, 1fr); gap: 3px; }
  .calcell { min-height: 44px; padding: 4px; }
  .caln { font-size: 14px; }
}

/* ---- 인쇄 ---- */
@media print {
  body { background: #fff; color: #111; }
  .topbar, .filterbar, .foot, .search, .afbar, .morebtn { display: none !important; }
  .panel, .kpi { border-color: #ccc; background: #fff; break-inside: avoid; }
  .tbar, .dot { print-color-adjust: exact; -webkit-print-color-adjust: exact; }
}
