:root{
  --ink:#1a2b4a; --ink-soft:#2d4368; --accent:#1f6feb; --accent-soft:#e8f1fe;
  --teal:#0f8a6e; --teal-soft:#e2f5ef; --amber:#b9770e; --amber-soft:#fdf2dd;
  --red:#c0392b; --red-soft:#fdecea; --green:#2e7d32; --green-soft:#e9f5ea;
  --bg:#f6f8fb; --surface:#ffffff; --surface-2:#f0f4f9;
  --line:#e2e8f1; --line-2:#cdd8e6; --text:#1a2333; --text-2:#5a6b85; --text-3:#93a1b8;
  --radius:10px; --radius-sm:7px; --radius-lg:14px;
  --shadow:0 1px 3px rgba(26,43,74,.06),0 1px 2px rgba(26,43,74,.04);
  --shadow-lg:0 8px 28px rgba(26,43,74,.12);
  --mono:'SF Mono',ui-monospace,'Cascadia Code',Consolas,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI','Pretendard','Apple SD Gothic Neo',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.mono{font-family:var(--mono)}

/* ===== 상단바 ===== */
.topbar{position:sticky;top:0;z-index:50;background:var(--ink);color:#fff;display:flex;align-items:center;gap:18px;padding:0 18px;height:52px}
.brand{font-size:18px;font-weight:700;letter-spacing:-.4px;display:flex;align-items:center;gap:7px}
.brand .dot{color:#5b9dff}
.brand small{font-size:11px;font-weight:400;color:#9fb4d6;letter-spacing:0}
.topnav{display:flex;gap:2px;flex:1;overflow-x:auto;height:100%}
.topnav a{display:flex;align-items:center;padding:0 13px;font-size:13.5px;color:#c2d1e8;border-bottom:2.5px solid transparent;white-space:nowrap;transition:.15s}
.topnav a:hover{color:#fff;background:rgba(255,255,255,.06)}
.topnav a.active{color:#fff;border-bottom-color:#5b9dff;font-weight:600}
.topbar .right{display:flex;align-items:center;gap:6px}
.topbar .right a{display:flex;align-items:center;gap:5px;font-size:13px;color:#c2d1e8;padding:6px 11px;border-radius:var(--radius-sm)}
.topbar .right a:hover{background:rgba(255,255,255,.1);color:#fff}
.topbar .right a.cta{background:#5b9dff;color:#0c2249;font-weight:600}

/* ===== 레이아웃 ===== */
.layout{display:grid;grid-template-columns:212px 1fr;min-height:calc(100vh - 52px)}
.sidebar{background:var(--surface);border-right:1px solid var(--line);padding:14px 0;overflow-y:auto}
.side-cat{font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;padding:12px 18px 6px}
.side-cat:first-child{padding-top:2px}
.side-link{display:flex;align-items:baseline;gap:8px;padding:7px 18px;font-size:13px;color:var(--text-2);border-left:2.5px solid transparent;transition:.12s}
.side-link:hover{background:var(--surface-2);color:var(--text)}
.side-link.active{background:var(--accent-soft);color:var(--accent);border-left-color:var(--accent);font-weight:600}
.side-link .sd{font-size:11px;color:var(--text-3);display:block;font-weight:400;margin-top:1px}
.main{padding:22px 28px;max-width:1100px}

/* ===== 페이지 헤더 ===== */
.phead{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap}
.phead h1{font-size:21px;font-weight:700;color:var(--ink);letter-spacing:-.3px;display:flex;align-items:center;gap:9px}
.phead .ref-badge{font-size:11px;font-weight:600;background:var(--surface-2);color:var(--text-2);padding:3px 9px;border-radius:20px;border:1px solid var(--line)}
.phead p{font-size:13.5px;color:var(--text-2);margin-top:4px;max-width:620px}
.phead .help{font-size:12.5px;color:var(--accent);display:inline-flex;align-items:center;gap:4px;margin-top:7px;cursor:pointer}

/* ===== 위저드 ===== */
.wizard{display:flex;align-items:center;gap:6px;margin-bottom:20px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:11px 16px}
.wstep{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--text-3)}
.wstep .n{width:21px;height:21px;border-radius:50%;background:var(--surface-2);color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.wstep.on{color:var(--accent);font-weight:600}.wstep.on .n{background:var(--accent);color:#fff}
.wstep.done{color:var(--teal)}.wstep.done .n{background:var(--teal);color:#fff}
.wline{flex:1;height:1px;background:var(--line);min-width:18px}

/* ===== 카드 ===== */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-h{padding:11px 16px;border-bottom:1px solid var(--line);font-size:13.5px;font-weight:600;display:flex;align-items:center;gap:8px;color:var(--ink)}
.card-b{padding:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:11px}

/* ===== 변수 선택 ===== */
.varbox{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px;min-height:120px}
.varbox .lbl{font-size:11.5px;color:var(--text-2);font-weight:600;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.var{display:flex;align-items:center;gap:7px;padding:6px 9px;margin-bottom:5px;background:var(--surface-2);border-radius:6px;font-size:13px;cursor:grab;border:1px solid transparent;transition:.12s}
.var:hover{border-color:var(--line-2);background:#fff}
.var .grip{color:var(--text-3);font-size:13px}
.var .tag{margin-left:auto;font-size:10.5px;padding:1px 7px;border-radius:10px}
.tag-cont{background:var(--accent-soft);color:var(--accent)}
.tag-nom{background:var(--teal-soft);color:var(--teal)}
.tag-ord{background:var(--amber-soft);color:var(--amber)}
.slot{border:1.5px dashed var(--line-2);border-radius:var(--radius-sm);padding:9px;min-height:46px;background:var(--surface-2);transition:.12s}
.slot.req{border-color:var(--accent);background:var(--accent-soft)}
.slot.grp{border-color:var(--teal);background:var(--teal-soft)}
.slot .ph{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:5px}
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;background:#fff;border:1px solid var(--line-2);border-radius:6px;font-size:12.5px;font-weight:500;margin:2px}
.chip .x{color:var(--text-3);font-size:12px;cursor:pointer}
.grp-detect{font-size:11px;color:var(--teal);margin-top:6px}

/* ===== 버튼 ===== */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:1px solid var(--line-2);background:#fff;color:var(--text);transition:.12s}
.btn:hover{background:var(--surface-2);border-color:var(--text-3)}
.btn-pri{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-pri:hover{background:#1a5fd0;border-color:#1a5fd0}
.btn-sm{padding:6px 11px;font-size:12px}
.btn-row{display:flex;flex-wrap:wrap;gap:7px;align-items:center}

/* ===== 결과 ===== */
.result-head{display:flex;align-items:center;gap:9px;margin:24px 0 12px;font-size:15px;font-weight:700;color:var(--ink)}
.interp{background:var(--green-soft);border:1px solid #bfe0c1;border-radius:var(--radius);padding:13px 15px;margin-bottom:14px}
.interp .t{font-size:11.5px;font-weight:700;color:var(--green);margin-bottom:4px;display:flex;align-items:center;gap:5px}
.interp .body{font-size:14px;line-height:1.7}
.stat-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:16px}
.scard{background:var(--surface-2);border-radius:var(--radius-sm);padding:11px 13px}
.scard .k{font-size:11.5px;color:var(--text-2)}
.scard .v{font-size:22px;font-weight:700;color:var(--ink);margin-top:2px;letter-spacing:-.5px}
.scard .v.sig{color:var(--green)}
table.apa{width:100%;border-collapse:collapse;font-size:13px}
table.apa thead th{border-top:1.5px solid var(--ink);border-bottom:1px solid var(--ink);padding:7px 8px;text-align:left;font-weight:600}
table.apa tbody td{border-bottom:1px solid var(--line);padding:6px 8px}
table.apa tbody tr:last-child td{border-bottom:1.5px solid var(--ink)}
table.apa .num{text-align:right;font-variant-numeric:tabular-nums}
.detail-toggle{border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px 13px;font-size:12.5px;color:var(--text-2);display:flex;align-items:center;gap:7px;cursor:pointer;margin:14px 0}
.detail-toggle:hover{background:var(--surface-2)}
.export-bar{display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding-top:14px;border-top:1px solid var(--line);margin-top:16px}
.export-bar .btn{font-size:12px;padding:6px 11px}
.btn-code{border-color:var(--accent);color:var(--accent)}
.btn-num{border-color:var(--amber);color:var(--amber)}

/* ===== 차트 영역 ===== */
.chart-ph{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-2);display:flex;align-items:center;justify-content:center;min-height:180px;color:var(--text-3);font-size:12.5px}

/* ===== 빈 상태 ===== */
.placeholder{color:var(--text-3);font-size:13px;text-align:center;padding:30px}

/* ===== 데이터셋 바 ===== */
.dsbar{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:8px 13px;margin-bottom:16px;font-size:12.5px;overflow-x:auto}
.dschip{display:flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;border:1px solid var(--line);color:var(--text-2);white-space:nowrap;cursor:pointer}
.dschip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:600}
.dschip small{font-size:10px;opacity:.7}

/* ===== 반응형 ===== */
@media(max-width:900px){.layout{grid-template-columns:1fr}.sidebar{display:none}.grid2{grid-template-columns:1fr}.stat-cards{grid-template-columns:repeat(2,1fr)}}
.mobile-menu{display:none}
@media(max-width:900px){.mobile-menu{display:flex}}
