:root{
  --accent:#2b6cb0;        /* 포인트 컬러 */
  --accent-dark:#234e7d;
  --bg:#f5f6f8;
  --card:#ffffff;
  --line:#e6e8eb;
  --text:#1f2937;
  --muted:#6b7280;
  --ok:#1f9d55;
  --err:#d64545;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI","Malgun Gothic",sans-serif;background:var(--bg);color:var(--text);font-size:15px}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit;font-size:15px}

/* 로그인 */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:36px 32px;width:340px;box-shadow:0 6px 24px rgba(0,0,0,.06)}
.login-card h1{font-size:19px;margin:0 0 4px}
.login-card p{color:var(--muted);font-size:13px;margin:0 0 20px}

/* 레이아웃 */
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:0 20px;display:flex;align-items:center;height:56px;gap:18px}
.topbar .brand{font-weight:700;color:var(--accent);font-size:16px}
.topbar .env{font-size:12px;padding:2px 8px;border-radius:10px;background:#eef4fb;color:var(--accent)}
.topbar .env.prod{background:#fdeaea;color:var(--err)}
.topbar .spacer{flex:1}
.topbar .who{color:var(--muted);font-size:13px}
.tabs{display:flex;gap:4px;padding:0 16px;background:#fff;border-bottom:1px solid var(--line)}
.tab{padding:12px 16px;border:none;background:none;color:var(--muted);font-size:14px;border-bottom:2px solid transparent}
.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}
.container{max-width:860px;margin:24px auto;padding:0 16px}

.card{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:8px;padding:20px;margin-bottom:18px}
.card h2{font-size:16px;margin:0 0 14px}
.muted{color:var(--muted);font-size:13px}

label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}
input[type=text],input[type=password],input[type=number],select,textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:6px;background:#fff}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
.row{display:flex;gap:12px}
.row>div{flex:1}

.btn{background:var(--accent);color:#fff;border:none;padding:11px 18px;border-radius:6px;font-size:15px}
.btn:hover{background:var(--accent-dark)}
.btn.secondary{background:#fff;color:var(--accent);border:1px solid var(--accent)}
.btn.ghost{background:#fff;color:var(--muted);border:1px solid var(--line)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-lg{width:100%;padding:14px;font-size:16px;font-weight:600;margin-top:8px}

.cmd-input{font-size:20px;padding:16px;text-align:center;letter-spacing:.5px}
.hint{font-size:13px;color:var(--muted);margin-top:8px;text-align:center}

.preview{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:16px;margin-top:14px}
.preview .pname{font-size:18px;font-weight:700}
.preview .pnum{color:var(--muted);font-size:13px}
.amt-table{width:100%;margin-top:12px;border-collapse:collapse}
.amt-table td{padding:6px 4px;border-top:1px solid var(--line)}
.amt-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}
.amt-table .total td{font-weight:700;font-size:17px;border-top:2px solid var(--accent)}

.match-list{margin-top:10px}
.match{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid var(--line);border-radius:6px;margin-bottom:6px;cursor:pointer}
.match:hover{border-color:var(--accent);background:#f8fafc}
.match .mnum{color:var(--muted);font-size:12px}

table.list{width:100%;border-collapse:collapse;font-size:14px}
table.list th,table.list td{padding:9px 10px;border-bottom:1px solid var(--line);text-align:left}
table.list th{color:var(--muted);font-weight:600;font-size:12px}
table.list td.num{text-align:right;font-variant-numeric:tabular-nums}
.badge{font-size:12px;padding:2px 8px;border-radius:10px}
.badge.ISSUED{background:#e7f6ee;color:var(--ok)}
.badge.FAILED{background:#fdeaea;color:var(--err)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1f2937;color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;opacity:0;transition:opacity .2s;z-index:50}
.toast.show{opacity:1}
.toast.err{background:var(--err)}
.toast.ok{background:var(--ok)}
.warn{background:#fff7ed;border-left-color:#d97706 !important;color:#92400e}
.hidden{display:none}
.dropzone{border:2px dashed var(--line);border-radius:8px;padding:28px;text-align:center;color:var(--muted);cursor:pointer}
.dropzone:hover{border-color:var(--accent);color:var(--accent)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px;margin-right:6px}
@keyframes s{to{transform:rotate(360deg)}}
