@font-face{font-family:Pretendard Variable;font-weight:45 920;font-style:normal;font-display:swap;src:url(/assets/PretendardVariable-CJuje-Rk.woff2) format("woff2-variations")}:root{--bg: #f4f6f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #e3e8ef;--border-strong: #cbd5e1;--text: #1f2933;--muted: #64748b;--primary: #1a6bbf;--primary-weak: #e8f0fb;--green: #2e7d32;--green-weak: #e9f7ef;--red: #cc0000;--red-weak: #fdecea;--radius: 10px;--radius-sm: 7px;--shadow: 0 1px 3px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04);--shadow-md: 0 4px 12px rgba(16, 24, 40, .08)}html[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-2: #172032;--border: #334155;--border-strong: #475569;--text: #e6edf5;--muted: #94a3b8;--primary: #6aa9e0;--primary-weak: #1c3a5a;--green: #56d364;--green-weak: #14351f;--red: #f2777a;--red-weak: #3a1d1f;--shadow: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 6px 18px rgba(0, 0, 0, .45)}html{background:var(--bg)}html,body{transition:background-color .15s ease}*{box-sizing:border-box}:root{--tracking: -.012em;--tracking-tight: -.02em;--font-scale-x: .96}body{margin:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:Pretendard Variable,Pretendard,system-ui,-apple-system,Segoe UI,Roboto,Noto Sans KR,sans-serif;font-size:15px;line-height:1.5;letter-spacing:var(--tracking);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.appbar h1,.card-head h2,.kpi .value,.dash-head h2,h3{letter-spacing:var(--tracking-tight)}.kpi .value{display:inline-block;transform:scaleX(var(--font-scale-x));transform-origin:left}.appbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 28px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.appbar .brand{display:flex;align-items:baseline;gap:12px}.appbar h1{font-size:19px;font-weight:700;margin:0;letter-spacing:-.01em}.appbar .sub{color:var(--muted);font-size:13px}.appbar .hint{font-size:12px;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);padding:6px 12px;border-radius:999px}.layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:20px;padding:20px 28px 40px;max-width:1200px;margin:0 auto;align-items:start}@media (max-width: 820px){.layout{grid-template-columns:minmax(0,1fr)}.side{position:static}}main{min-width:0}@media (max-width: 640px){.appbar .hint{display:none}}.side{position:sticky;top:84px}.side-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.side-head .title{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.side-head .count{font-size:12px;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:2px 9px}.btn-new{width:100%;padding:10px 12px;margin-bottom:12px;border:1px solid var(--primary);background:var(--primary-weak);color:var(--primary);font-weight:600;font-size:14px;border-radius:var(--radius-sm);cursor:pointer}.btn-new:hover{background:#dce8fa}.spec-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.spec-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 13px;text-align:left;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);transition:border-color .12s,background .12s}.spec-item:hover{border-color:var(--border-strong)}.spec-item.active{border-color:var(--primary);background:var(--primary-weak)}.spec-item .name{font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;min-width:0}.spec-item .name .key{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spec-item .meta{color:var(--muted);font-size:12px}.tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid transparent;white-space:nowrap}.tag-common{background:var(--primary-weak);color:var(--primary)}.tag-on{background:var(--green-weak);color:var(--green)}.tag-off{background:#f1f5f9;color:var(--muted)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border)}.card-head .h{display:flex;align-items:center;gap:10px}.card-head h2{font-size:17px;margin:0;font-weight:700}.card-body{padding:22px}.alert{margin:16px 22px 0;padding:10px 14px;border-radius:var(--radius-sm);font-size:13.5px}.alert-err{background:var(--red-weak);color:var(--red);border:1px solid #f5c6cb}.alert-ok{background:var(--green-weak);color:var(--green);border:1px solid #bfe3c6}.grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}@media (max-width: 620px){.grid{grid-template-columns:1fr}}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1 / -1}.field label{font-size:13px;font-weight:600;color:var(--muted)}.input,.select{padding:9px 11px;font-size:14px;color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);width:100%}.input:focus,.select:focus{outline:2px solid var(--primary-weak);border-color:var(--primary)}.input:disabled{background:var(--surface-2);color:var(--muted)}.switches{display:flex;gap:22px;align-items:center;margin-top:4px}.switch{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;cursor:pointer}.switch input{width:17px;height:17px;accent-color:var(--primary);cursor:pointer}.section-title{display:flex;align-items:center;justify-content:space-between;margin:26px 0 12px;padding-top:20px;border-top:1px solid var(--border)}.section-title h3{font-size:15px;margin:0;font-weight:700}.section-title .desc{font-size:12.5px;color:var(--muted)}.table-wrap{border:1px solid var(--border);border-radius:var(--radius-sm);overflow-x:auto}table.fields{width:100%;min-width:600px;border-collapse:collapse;font-size:14px}table.fields th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;background:var(--surface-2);padding:10px 12px;border-bottom:1px solid var(--border)}table.fields th.center,table.fields td.center{text-align:center}table.fields td{padding:7px 12px;border-bottom:1px solid var(--border);vertical-align:middle}table.fields tr:last-child td{border-bottom:none}table.fields tbody tr:hover{background:var(--surface-2)}.cell{width:100%;padding:7px 9px;border:1px solid var(--border-strong);border-radius:6px;font-size:13.5px;background:var(--surface)}.cell:focus{outline:2px solid var(--primary-weak);border-color:var(--primary)}table.fields input[type=checkbox]{width:17px;height:17px;accent-color:var(--primary);cursor:pointer}.icon-del{border:none;background:transparent;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:6px}.icon-del:hover{color:var(--red);background:var(--red-weak)}.btn-add{margin-top:12px;padding:8px 14px;font-size:13.5px;font-weight:500;border:1px dashed var(--border-strong);background:var(--surface-2);color:var(--muted);border-radius:var(--radius-sm);cursor:pointer}.btn-add:hover{border-color:var(--primary);color:var(--primary)}.actions{display:flex;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.btn{padding:10px 20px;font-size:14px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;border:1px solid transparent}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#14589f}.btn-ghost{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.btn-ghost:hover{background:var(--surface-2)}.btn-danger{background:var(--surface);color:var(--red);border-color:#f0b7bb;margin-left:auto}.btn-danger:hover{background:var(--red-weak)}.empty{text-align:center;color:var(--muted);padding:60px 20px}.empty .big{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}.appbar .tools{display:flex;align-items:center;gap:12px}.theme-toggle{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;font-size:13px;font-weight:500;cursor:pointer;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:999px}.theme-toggle:hover{background:var(--surface-2)}.search{width:100%;padding:9px 12px;margin-bottom:10px;font-size:14px;color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm)}.search:focus{outline:2px solid var(--primary-weak);border-color:var(--primary)}.side-empty{color:var(--muted);font-size:13px;padding:10px 4px}.cell.invalid,.input.invalid{border-color:var(--red);background:var(--red-weak)}.cell.invalid:focus,.input.invalid:focus{outline-color:var(--red-weak)}.issues{margin:0;padding-left:18px}.issues li{margin:2px 0}.btn-primary:disabled{background:var(--border-strong);cursor:not-allowed;opacity:.7}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.login-card{width:100%;max-width:360px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px 26px;box-shadow:0 8px 30px #00000014;display:flex;flex-direction:column;gap:16px}.login-brand{text-align:center;margin-bottom:4px}.login-brand h1{margin:0;font-size:24px;letter-spacing:var(--tracking)}.login-brand .sub{color:var(--muted);font-size:13px}.login-btn{width:100%;justify-content:center;padding:10px;font-size:15px}.login-err{color:var(--red);background:var(--red-weak);border:1px solid var(--red);border-radius:8px;padding:8px 12px;font-size:13px}.drag-handle{cursor:grab;color:var(--muted);font-size:16px;-webkit-user-select:none;user-select:none;padding:4px 6px;text-align:center}.drag-handle:active{cursor:grabbing}tr.dragging{opacity:.45}tr.drop-target td{box-shadow:inset 0 2px 0 var(--primary)}table.fields td.grip{width:34px;padding-left:8px;padding-right:0}table.fields th.grip{width:34px}.appbar-left{display:flex;align-items:center;gap:22px}.tabs{display:flex;gap:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:3px}.tab{padding:7px 16px;border:none;background:transparent;cursor:pointer;color:var(--muted);font-weight:600;font-size:13.5px;border-radius:999px}.tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow)}.tab:hover:not(.active){color:var(--text)}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;margin:0;width:18px;height:18px;flex:none;position:relative;cursor:pointer;border:1.5px solid var(--border-strong);border-radius:5px;background:var(--surface);transition:background .1s,border-color .1s}input[type=checkbox]:hover{border-color:var(--primary)}input[type=checkbox]:checked{background:var(--primary);border-color:var(--primary)}input[type=checkbox]:checked:after{content:"";position:absolute;left:5px;top:1.5px;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}input[type=checkbox]:focus-visible{outline:2px solid var(--primary-weak);outline-offset:1px}html[data-density=compact]{font-size:14px}html[data-density=compact] .card-head{padding:12px 18px}html[data-density=compact] .card-body{padding:16px}html[data-density=compact] .spec-item{padding:8px 11px}html[data-density=compact] .input,html[data-density=compact] .select{padding:7px 9px}html[data-density=compact] table.fields td{padding:4px 8px}html[data-density=compact] table.fields th{padding:8px}html[data-density=compact] .cell{padding:5px 7px}html[data-density=compact] .grid{gap:12px 16px}html[data-density=compact] .section-title{margin:18px 0 10px;padding-top:14px}.dash{display:flex;flex-direction:column;gap:20px;padding:20px 28px 40px;max-width:1200px;margin:0 auto}.dash-head{display:flex;align-items:center;justify-content:space-between}.dash-head h2{margin:0;font-size:18px}.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}@media (max-width: 820px){.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 18px}.kpi .label{font-size:12.5px;color:var(--muted);font-weight:600}.kpi .value{font-size:26px;font-weight:700;margin-top:6px;letter-spacing:-.02em}.kpi .unit{font-size:14px;color:var(--muted);font-weight:600;margin-left:4px}.grid2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px}@media (max-width: 900px){.grid2{grid-template-columns:minmax(0,1fr)}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.panel-head{padding:15px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.panel-head h3{margin:0;font-size:15px}.panel-head .desc{font-size:12.5px;color:var(--muted)}.panel-body{padding:12px 20px 18px;flex:1;display:flex;flex-direction:column}.bars-fill{flex:1;display:flex;flex-direction:column;justify-content:space-between;gap:2px;min-height:220px}.chart-fill{flex:1;display:flex;flex-direction:column;justify-content:center}.bar-row{display:grid;grid-template-columns:150px minmax(0,1fr) auto;gap:12px;align-items:center;padding:7px 0}.bar-name{font-size:13.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{display:block;height:10px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;overflow:hidden}.bar-fill{display:block;height:100%;background:var(--primary);border-radius:999px;min-width:2px}.bar-val{font-size:12.5px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}.utable{width:100%;border-collapse:collapse;font-size:13.5px}.utable th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em;padding:8px 10px;border-bottom:1px solid var(--border)}.utable td{padding:8px 10px;border-bottom:1px solid var(--border)}.utable td.num,.utable th.num{text-align:right;font-variant-numeric:tabular-nums}.utable tr:last-child td{border-bottom:none}.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.res-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;background:var(--surface-2)}.res-card .host{font-weight:700;margin-bottom:10px}.meter{margin:9px 0}.meter .top{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:4px}.meter .track{height:8px;background:var(--surface);border:1px solid var(--border);border-radius:999px;overflow:hidden}.meter .fill{height:100%;border-radius:999px}.dash-empty{color:var(--muted);font-size:13.5px;padding:18px 4px;text-align:center}.tl-legend{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:8px;font-size:12.5px;color:var(--muted);align-items:center}.tl-key{display:flex;align-items:center;gap:6px}.tl-toggle{border:none;background:transparent;cursor:pointer;padding:0;font:inherit;color:var(--text)}.tl-toggle:hover{color:var(--primary)}.tl-toggle.off{opacity:.45;text-decoration:line-through}.tl-key i{width:13px;height:3px;border-radius:2px;display:inline-block}.tl-svg{width:100%;height:auto;display:block;overflow:visible}.tl-grid{stroke:var(--border)}.tl-axis{fill:var(--muted);font-size:10px;letter-spacing:0}.tl-threshold{stroke-dasharray:5 4}.res-tl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.res-tl-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}.res-tl-card .host{font-weight:700;margin-bottom:4px;font-size:14px}.tl-sub{font-size:12px;color:var(--muted);font-weight:600;margin:12px 0 4px}.bar-row.compact{grid-template-columns:118px minmax(0,1fr) auto;padding:5px 0;font-size:13px}.tl-wrap{position:relative;cursor:crosshair;-webkit-user-select:none;user-select:none}.tl-cross{stroke:var(--muted);stroke-dasharray:3 3}.tl-sel{fill:var(--primary);opacity:.12}.tl-reset{margin-left:auto;padding:3px 11px;font-size:12px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:999px;cursor:pointer}.tl-reset:hover{background:var(--surface-2)}.tl-tip{position:absolute;top:2px;transform:translate(-50%);pointer-events:none;background:var(--surface);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-md);padding:8px 10px;font-size:12.5px;min-width:118px;z-index:5}.tl-tip-t{font-weight:700;margin-bottom:5px;color:var(--muted)}.tl-tip-row{display:flex;justify-content:space-between;gap:14px;margin:2px 0}.tl-tip-k{display:flex;align-items:center;gap:6px}.tl-tip-k i{width:10px;height:10px;border-radius:3px;display:inline-block}.tl-tip-v{font-variant-numeric:tabular-nums;font-weight:600}.period{display:flex;gap:3px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;padding:3px}.period button{padding:5px 12px;border:none;background:transparent;color:var(--muted);font-weight:600;font-size:12.5px;border-radius:999px;cursor:pointer}.period button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow)}.dash-tools{display:flex;align-items:center;gap:10px}.toast-host{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:10px;z-index:100}.toast{display:flex;align-items:center;gap:9px;min-width:220px;max-width:380px;padding:12px 16px;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);font-size:14px;font-weight:500;color:#fff;animation:toast-in .18s ease}.toast .ti{font-weight:700;font-size:15px}.kbd{font-size:11px;color:var(--muted);margin-left:8px;font-weight:500}.toast-ok{background:#2e7d32}.toast-err{background:#c00}.toast-info{background:#334155}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
