:root{--bg:#f7f7f8;--surface:#fff;--line:#e5e7eb;--text:#111827;--muted:#6b7280;--accent:#2563eb;--warn:#f59e0b;--list-panel-width:300px}
*{box-sizing:border-box}
body{margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);background:var(--bg);font-size:13px}
.topbar{position:sticky;top:0;z-index:10;display:flex;gap:10px;align-items:center;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--line)}
.topbar h1{margin:0;font-size:15px;font-weight:800;letter-spacing:-.3px}
.meta{color:var(--muted);font-size:11px}
.spacer{flex:1}
.btn{border:1px solid var(--line);background:#fff;color:var(--text);padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;border-radius:7px;white-space:nowrap}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn:disabled{opacity:.45;cursor:not-allowed;border-color:var(--line);color:var(--muted)}
.tabs{display:flex;border-bottom:1px solid var(--line);background:var(--surface);padding:0 14px}
.tab{padding:8px 16px;font-size:12px;font-weight:700;cursor:pointer;border-bottom:2px solid transparent;color:var(--muted);margin-bottom:-1px;white-space:nowrap}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.layout{display:flex;align-items:stretch;padding:10px;height:calc(100vh - 92px);gap:0}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:10px;overflow:hidden;min-height:0;min-width:0;display:flex;flex-direction:column}
.panel-list{width:var(--list-panel-width);min-width:220px;max-width:420px;flex:0 0 auto}
.panel-detail{flex:1 1 auto;min-width:0}
.splitter{width:10px;margin:0 6px;cursor:col-resize;position:relative;flex:0 0 auto}
.splitter::before{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:2px;height:100%;background:#d1d5db;border-radius:999px}
.splitter:hover::before,.splitter.dragging::before{background:var(--accent)}
body.resizing-layout,body.resizing-layout *{cursor:col-resize !important;user-select:none !important}
.panel-head{padding:8px 12px;border-bottom:1px solid var(--line);font-size:11px;color:var(--muted);font-weight:700}
.list{overflow:auto;padding:6px;display:flex;flex-direction:column;gap:5px;flex:1}
.item{border:1px solid var(--line);border-radius:8px;padding:9px 10px;cursor:pointer;background:#fff}
.item:hover{border-color:#93c5fd}.item.active{border-color:var(--accent);box-shadow:0 0 0 2px #dbeafe}
.item-top{display:flex;gap:5px;align-items:center;margin-bottom:5px;flex-wrap:wrap}
.item-id{font-size:11px;font-weight:700;color:#374151}
.item-sub{font-size:10px;color:var(--muted);line-height:1.4}
.badge{display:inline-block;padding:1px 6px;border-radius:999px;font-size:10px;font-weight:700;border:1px solid var(--line);color:#374151;background:#f9fafb}
.badge.ktas1{color:#7f1d1d;background:#fee2e2;border-color:#fecaca}
.badge.ktas2{color:#7c2d12;background:#ffedd5;border-color:#fed7aa}
.badge.ktas4{color:#1e40af;background:#dbeafe;border-color:#bfdbfe}
.badge.ktas5{color:#14532d;background:#dcfce7;border-color:#bbf7d0}
.badge.grade-r{color:#7f1d1d;background:#fee2e2;border-color:#fecaca}
.badge.grade-d{color:#713f12;background:#fef3c7;border-color:#fde68a}
.badge.grade-l{color:#374151;background:#f3f4f6;border-color:#e5e7eb}
.badge.v0{color:var(--muted)}.badge.v1{color:#14532d;background:#dcfce7;border-color:#bbf7d0}
.badge.v2{color:#7f1d1d;background:#fee2e2;border-color:#fecaca}
.badge.v3{color:#92400e;background:#fef3c7;border-color:#fcd34d}
.badge.v4{color:#1e40af;background:#dbeafe;border-color:#93c5fd}
.badge.user-tag{background:#eef2ff;border-color:#c7d2fe;color:#3730a3;font-size:10px}
.badge.rep-tag{background:#ecfeff;border-color:#a5f3fc;color:#155e75;font-size:10px}
.badge.auto-tag{background:#f0fdf4;border-color:#bbf7d0;color:#166534;font-size:10px}
.badge.stage1{background:#fff7ed;border-color:#fed7aa;color:#9a3412;font-size:10px}
.detail{overflow:auto;padding:12px;display:flex;flex-direction:column;gap:10px;flex:1}
.route-bar{display:grid;grid-template-columns:minmax(0,1.2fr) auto minmax(0,1.2fr) auto minmax(86px,.55fr) auto minmax(94px,.6fr);gap:0;align-items:center;border:1px solid var(--line);border-radius:10px;background:#fff;overflow:hidden;margin-bottom:2px}
.route-cell{padding:10px 12px;border-right:1px solid var(--line);min-width:0}
.route-cell:last-child{border-right:none}
.route-arrow{padding:0 8px;color:var(--muted);font-size:16px;border-right:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.route-k{font-size:10px;color:var(--muted);font-weight:700;margin-bottom:3px;white-space:nowrap}
.route-v{font-size:13px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.route-v.accent{color:var(--accent)}
.route-v.highlight{color:#0f766e;font-size:14px}
.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:7px}
.sum-box{border:1px solid var(--line);background:#fff;border-radius:8px;padding:7px 9px}
.sum-k{color:var(--muted);font-size:10px;margin-bottom:2px}
.sum-v{font-size:13px;font-weight:700}
.section{border:1px solid var(--line);border-radius:9px;background:#fff;overflow:hidden}
.sec-title{padding:7px 10px;border-bottom:1px solid var(--line);background:#f9fafb;font-size:11px;color:#374151;font-weight:700}
.sec-title.nedis{background:#eff6ff;color:#1e40af}
.sec-title.vital{background:#f0fdf4;color:#166534}
table.kv{width:100%;border-collapse:collapse;font-size:12px}
table.kv td{border-top:1px solid #f1f5f9;padding:5px 10px;vertical-align:top}
table.kv tr:first-child td{border-top:none}
table.kv td.k{width:140px;color:var(--muted);font-weight:600;white-space:nowrap;font-size:11px}
.assessment-box{border:1px solid var(--line);border-left:4px solid var(--warn);background:#fffbe6;border-radius:9px;padding:10px 12px}
.assessment-title{font-size:11px;font-weight:700;color:#92400e;margin-bottom:6px}
.assessment-text{font-size:13px;line-height:1.7;white-space:pre-wrap;color:#111827;font-weight:500}
.assessment-empty{color:var(--muted);font-style:italic;font-size:12px}
.stage-wrap{border:1px solid var(--line);border-radius:9px;background:#fff;overflow:hidden}
.stage-head{padding:7px 10px;border-bottom:1px solid var(--line);background:#f8fafc;font-size:11px;color:#1f2937;font-weight:800}
.verdict-wrap{border:1px solid var(--line);background:#fff;border-radius:9px;padding:10px 12px}
.verdict-head{font-size:11px;color:var(--muted);font-weight:700;margin-bottom:8px}
.verdict-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.vbtn{border:1px solid var(--line);border-radius:7px;padding:6px 12px;background:#fff;font-size:12px;font-weight:700;cursor:pointer;min-width:88px;text-align:center}
.vbtn:hover{border-color:var(--accent)}
.vbtn.active[data-code="1"]{background:#dcfce7;border-color:#86efac;color:#14532d}
.vbtn.active[data-code="2"]{background:#fee2e2;border-color:#fca5a5;color:#7f1d1d}
.vbtn.active[data-code="3"]{background:#fef3c7;border-color:#fcd34d;color:#92400e}
.vbtn.active[data-code="4"]{background:#dbeafe;border-color:#93c5fd;color:#1e40af}
.memo-row{display:flex;gap:6px;align-items:center;margin-top:6px}
.memo-input{flex:1;border:1px solid #d1d5db;border-radius:7px;padding:7px 9px;font-size:12px;background:#fff}
.memo-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #dbeafe}
.memo-apply{border:1px solid var(--line);border-radius:7px;padding:7px 10px;background:#fff;font-size:12px;font-weight:700;cursor:pointer}
.verdict-tip{font-size:10px;color:var(--muted);margin-top:6px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px;align-items:start}
.tags-wrap{border:1px solid var(--line);background:#fff;border-radius:9px;padding:10px 12px}
.tags-head{font-size:11px;font-weight:700;color:#4b5563;margin-bottom:8px}
.tag-groups{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tag-group{border:1px solid #eef2f7;border-radius:8px;padding:8px;background:#fafbfd}
.tag-group-title{font-size:10px;color:#6b7280;font-weight:700;margin-bottom:6px}
.tag-options{display:flex;flex-wrap:wrap;gap:6px}
.tag-option{display:inline-flex;gap:5px;align-items:center;padding:4px 6px;border:1px solid #dbe3ee;border-radius:999px;background:#fff;font-size:11px;color:#334155;cursor:pointer}
.tag-option input{margin:0}
.user-tag-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px}
.user-tag-item{border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#fff}
.user-tag-name{font-size:11px;font-weight:700;color:#374151;margin-bottom:4px}
.user-tag-values{display:flex;flex-wrap:wrap;gap:5px;min-height:20px}
.empty{padding:24px;color:var(--muted);text-align:center;font-size:13px}
#drop-overlay{display:none;position:fixed;inset:0;z-index:999;background:rgba(37,99,235,.12);border:3px dashed var(--accent);align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--accent)}
#drop-overlay.visible{display:flex}

.login-gate{position:fixed;inset:0;background:#f5f7fb;display:flex;align-items:center;justify-content:center;z-index:2000}
.login-card{width:min(640px,92vw);background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px 24px 20px;box-shadow:0 12px 42px rgba(15,23,42,.12)}
.login-top{display:flex;gap:14px;align-items:center;margin-bottom:12px}
.login-lock{width:56px;height:56px;object-fit:contain;flex:0 0 auto}
.login-title{font-size:18px;font-weight:800;color:#111827;line-height:1.2}
.login-sub{margin-top:2px;color:#6b7280;font-size:12px}
.profile-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 12px}
.profile-btn{border:1px solid #d1d5db;border-radius:10px;padding:10px 8px;background:#fff;cursor:pointer;display:flex;flex-direction:column;gap:6px;align-items:center}
.profile-btn.active{border-color:#2563eb;box-shadow:0 0 0 2px #dbeafe}
.profile-avatar{width:30px;height:30px;border-radius:999px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700}
.profile-name{font-size:11px;font-weight:700;color:#374151}
.login-row{display:flex;gap:8px;align-items:center;margin-top:8px}
.login-pass{flex:1;border:1px solid #d1d5db;border-radius:8px;padding:10px 10px;font-size:13px}
.login-pass:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #dbeafe}
.login-enter{border:1px solid #2563eb;background:#2563eb;color:#fff;border-radius:8px;padding:10px 12px;font-size:13px;font-weight:700;cursor:pointer}
.login-enter:disabled{opacity:.6;cursor:not-allowed}
.login-msg{min-height:16px;color:#b91c1c;font-size:11px;margin-top:6px}

.skeleton-wrap{display:flex;flex-direction:column;gap:10px;padding:4px}
.skeleton-line,.skeleton-box,.skeleton-card{position:relative;overflow:hidden;background:#eef2f7;border-radius:8px}
.skeleton-line::after,.skeleton-box::after,.skeleton-card::after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);animation:skeleton-shimmer 1.1s infinite}
.skeleton-line{height:14px}
.skeleton-line.w80{width:80%}
.skeleton-line.w60{width:60%}
.skeleton-line.w40{width:40%}
.skeleton-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.skeleton-box{height:58px}
.skeleton-card{height:140px}
@keyframes skeleton-shimmer{100%{transform:translateX(100%)}}

@media(max-width:1280px){.route-cell{padding:8px 9px}.route-v{font-size:12px}.route-v.highlight{font-size:13px}.route-arrow{padding:0 6px;font-size:13px}}
@media(max-width:1100px){.layout{height:auto;flex-direction:column}.panel-list{width:100%;max-width:none}.splitter{display:none}.two-col,.tag-groups{grid-template-columns:1fr}.route-bar{grid-template-columns:1fr;border-radius:0}.route-arrow{display:none}}
