:root{
  --bg:#f4f6fb; --card:#fff; --line:#e5e8f0; --text:#1c2330; --muted:#6b7280;
  --primary:#4f46e5; --primary-d:#4338ca; --ss:#03c75a; --cp:#ff6f0f;
  --warn:#b45309; --err:#dc2626; --ok:#059669; --soft:#eef2ff;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Pretendard","Apple SD Gothic Neo","Malgun Gothic","맑은 고딕",system-ui,sans-serif;
  line-height:1.5;
  /* 페이지 스크롤 제거 — 테이블만 스크롤 */
  height:100vh;overflow:hidden;display:flex;flex-direction:column;
}

/* ── 상단바 ── */
.topbar{background:linear-gradient(120deg,#4f46e5,#7c3aed);color:#fff;padding:20px 0 18px;flex-shrink:0}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar h1{margin:0;font-size:22px;font-weight:800;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}
.topbar h1 .logo{font-size:24px}
.topbar .sub{margin:3px 0 0;font-size:13px;opacity:.92}
.topbar .sub strong{color:#ffe680}
.nav{display:flex;gap:8px}
.nav a{color:#fff;text-decoration:none;font-size:13px;font-weight:600;background:rgba(255,255,255,.14);
  padding:8px 14px;border-radius:9px;transition:.15s}
.nav a:hover{background:rgba(255,255,255,.26)}
.nav a.on{background:#fff;color:var(--primary)}

.wrap{max-width:1280px;margin:0 auto;padding:0 18px;width:100%}
main.wrap{padding-top:18px;padding-bottom:16px;flex:1;min-height:0;display:flex;flex-direction:column}

/* ── 툴바 ── */
.toolbar{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px;
  margin-bottom:14px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;flex-shrink:0;
  box-shadow:0 2px 10px rgba(20,30,60,.04)}
.toolbar .spacer{flex:1}
.search{position:relative;flex:1;min-width:220px;max-width:380px}
.search input{width:100%;padding:10px 12px 10px 34px;border:1px solid #d3d8e6;border-radius:10px;
  font-size:14px;font-family:inherit;background:#fff}
.search .ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px}
.search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,.12)}
select.filter{padding:10px 12px;border:1px solid #d3d8e6;border-radius:10px;font-size:14px;
  font-family:inherit;background:#fff;min-width:140px;cursor:pointer}
select.filter:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,.12)}

.btn{border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;
  font-family:inherit;padding:10px 16px;transition:.15s;display:inline-flex;align-items:center;gap:7px;
  white-space:nowrap}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn.primary{background:var(--primary);color:#fff}
.btn.primary:not(:disabled):hover{background:var(--primary-d)}
.btn.ghost{background:#eef0f7;color:#3a4150}
.btn.ghost:not(:disabled):hover{background:#e2e6f1}
.btn.ss{background:var(--ss);color:#fff}.btn.ss:not(:disabled):hover{filter:brightness(.93)}
.btn.cp{background:var(--cp);color:#fff}.btn.cp:not(:disabled):hover{filter:brightness(.93)}
.btn.danger{background:#fef2f2;color:var(--err)}
.btn.danger:not(:disabled):hover{background:#fde4e4}
.btn.sm{padding:6px 10px;font-size:12.5px;font-weight:600;border-radius:8px}
.btn.lg{padding:12px 20px;font-size:15px}

/* ── 카운트/뱃지 ── */
.counts{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--muted)}
.pill{background:var(--soft);color:var(--primary);padding:5px 12px;border-radius:20px;font-size:13px;font-weight:700}
.pill b{font-weight:800}
.pill.gray{background:#f1f3f8;color:#475063}
.save-stat{font-size:12.5px;font-weight:700;padding:5px 11px;border-radius:20px;white-space:nowrap}
.save-stat.st-saved{background:#ecfdf5;color:#059669}
.save-stat.st-saving{background:#eef2ff;color:#4f46e5}
.save-stat.st-error{background:#fef2f2;color:#dc2626}

/* ── 액션 바(내보내기 등) ── */
.actionbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px;flex-shrink:0}
.actionbar .grouplabel{font-size:12px;color:var(--muted);font-weight:700;margin-right:2px}
.divider{width:1px;height:24px;background:var(--line);margin:0 4px}

/* ── 테이블 (남은 공간 채우고 내부 스크롤) ── */
.tablecard{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:0 2px 10px rgba(20,30,60,.04);flex:1;min-height:0;display:flex;flex-direction:column}
.tablescroll{flex:1;min-height:0;overflow:auto}
table.master{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
table.master thead th{position:sticky;top:0;z-index:2;background:#f7f8fc;color:#475063;font-weight:700;
  text-align:center;padding:11px 12px;border-bottom:2px solid var(--line);border-right:1px solid var(--line);
  white-space:nowrap;user-select:none}
table.master thead th.sortable{cursor:pointer}
table.master thead th.sortable:hover{background:#eef0f7}
table.master thead th .arrow{color:var(--primary);font-size:11px;margin-left:3px}
table.master tbody td{padding:9px 12px;text-align:center;border-bottom:1px solid #eef0f5;
  border-right:1px solid #eef0f5;vertical-align:middle}
/* 돈(가격·마진)만 우측정렬, 나머지는 중앙정렬 */
table.master .col-price,table.master .col-margin{text-align:right}
table.master th:last-child,table.master td:last-child{border-right:none}
table.master tbody tr:hover{background:#f8f9ff}
table.master tbody tr.sel{background:#eef2ff}
.col-num{width:54px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.col-chk{width:38px;text-align:center}
.col-sku{font-family:"D2Coding","Consolas",monospace;color:#475063;white-space:nowrap}
.col-name{min-width:260px;font-weight:600}
.col-cat,.col-sub{white-space:nowrap;color:#475063}
.cat-tag{display:inline-block;background:#f1f3f8;color:#475063;padding:2px 9px;border-radius:6px;font-size:12px}
.col-price{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.col-margin{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;color:var(--ok);font-weight:600}
.col-margin.neg{color:var(--err)}
.col-img{font-family:"D2Coding","Consolas",monospace;color:#8a90a0;font-size:12px;white-space:nowrap;
  max-width:140px;overflow:hidden;text-overflow:ellipsis}
.col-state{white-space:nowrap;text-align:center}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:3px}
.dot.on{background:var(--ok)}.dot.off{background:#c4c9d4}
.col-act{white-space:nowrap}
.empty{padding:50px 20px;text-align:center;color:var(--muted)}
.empty .big{font-size:38px;margin-bottom:8px}

/* ── 페이지네이션 ── */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:12px;flex-shrink:0}
.pg-info{font-size:13px;color:var(--muted)}
.pg-btns{display:flex;gap:4px;flex-wrap:wrap}
.pg{min-width:34px;height:34px;padding:0 9px;border:1px solid var(--line);background:#fff;color:#3a4150;
  border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:.12s}
.pg:hover:not(:disabled):not(.on){background:#eef2ff;border-color:#c7cdf0}
.pg.on{background:var(--primary);color:#fff;border-color:var(--primary);cursor:default}
.pg:disabled{opacity:.4;cursor:not-allowed}
.pg-dots{padding:0 4px;color:var(--muted);align-self:center}

/* ── 모달 ── */
.modal{position:fixed;inset:0;background:rgba(18,22,38,.5);display:none;align-items:flex-start;
  justify-content:center;z-index:50;padding:34px 16px;overflow:auto}
.modal.open{display:flex}
.modal-card{background:#fff;border-radius:16px;width:100%;max-width:680px;box-shadow:0 18px 60px rgba(10,15,40,.35);
  animation:pop .16s ease}
@keyframes pop{from{transform:translateY(8px) scale(.99);opacity:.6}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.modal-head h3{margin:0;font-size:18px;font-weight:800}
.modal-head .x{border:none;background:#f1f3f8;width:32px;height:32px;border-radius:8px;cursor:pointer;
  font-size:18px;color:#475063;line-height:1}
.modal-head .x:hover{background:#e2e6f1}
.modal-body{padding:20px 22px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fgrid label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#3a4150;font-weight:600}
.fgrid label.wide{grid-column:1/-1}
.fgrid .req{color:var(--err)}
.fgrid input,.fgrid select,.fgrid textarea{padding:10px 12px;border:1px solid #d3d8e6;border-radius:9px;
  font-size:14px;font-family:inherit;background:#fff;width:100%}
.fgrid textarea{resize:vertical;min-height:78px;font-family:"D2Coding","Consolas",monospace;font-size:12.5px}
.fgrid input:focus,.fgrid select:focus,.fgrid textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(79,70,229,.12)}
.fgrid .hint{font-size:11.5px;color:var(--muted);font-weight:500}
.fld-err{border-color:var(--err)!important}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line);background:#fafbff;border-radius:0 0 16px 16px}

/* ── 스마트스토어 설정 모달 ── */
.ss-summary{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534;border-radius:10px;
  padding:10px 14px;font-size:13.5px;margin-bottom:16px}
.ss-summary b{font-weight:800}
.ss-warn{color:var(--err);font-weight:700}
.ss-h{margin:20px 0 10px;font-size:14.5px;font-weight:800;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ss-h:first-of-type{margin-top:4px}
.ss-req{background:#fee2e2;color:var(--err);font-size:11px;font-weight:700;padding:2px 8px;border-radius:6px}
.ss-sub{font-size:11.5px;color:var(--muted);font-weight:500}
.ss-catmap{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;max-height:210px;overflow:auto;
  border:1px solid var(--line);border-radius:10px;padding:12px;background:#fafbff}
.ss-catrow{display:flex;align-items:center;gap:8px}
.ss-catname{flex:1;font-size:12.5px;color:#3a4150;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ss-catname b{color:var(--muted);font-weight:700;font-size:11px}
.ss-catcode{width:120px;padding:7px 9px;border:1px solid #d3d8e6;border-radius:8px;font-size:13px;font-family:inherit}
.ss-catcode:focus{outline:none;border-color:var(--ss);box-shadow:0 0 0 3px rgba(3,199,90,.14)}
.modal-body h4.ss-h+.fgrid{margin-top:0}
@media(max-width:760px){ .ss-catmap{grid-template-columns:1fr} }
.ss-chk{flex-direction:row!important;align-items:center;gap:8px!important}
.ss-chk input{width:auto!important}

/* ── 쿠팡 카테고리 검색 ── */
.cp-search{margin-bottom:10px}
.cp-search>input{width:100%;padding:10px 12px;border:1px solid #d3d8e6;border-radius:9px;font-size:14px;font-family:inherit}
.cp-search>input:focus{outline:none;border-color:var(--cp);box-shadow:0 0 0 3px rgba(255,111,15,.14)}
.cp-results{max-height:170px;overflow:auto;margin-top:6px;border:1px solid var(--line);border-radius:9px}
.cp-results:empty{display:none}
.cp-ritem{padding:7px 11px;font-size:12.5px;cursor:pointer;border-bottom:1px solid #f1f3f8;color:#3a4150}
.cp-ritem:hover{background:#fff7ed}
.cp-rinfo{padding:10px 12px;color:var(--muted);font-size:12.5px}
.cp-catcode.cp-filled{border-color:var(--cp);background:#fff7ed}
.cp .modal-foot,.modal-foot .btn.cp{}

/* ── 토스트 ── */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);
  background:#1c2330;color:#fff;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;
  opacity:0;pointer-events:none;transition:.25s;z-index:80;box-shadow:0 8px 30px rgba(0,0,0,.25)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.ok{background:#065f46}.toast.err{background:#991b1b}

.footer{text-align:center;color:#9aa1b1;font-size:12px;margin-top:8px;flex-shrink:0}

@media(max-width:760px){
  .fgrid{grid-template-columns:1fr}
  .topbar .wrap{flex-direction:column;align-items:flex-start;gap:10px}
}
