/* 통합 운영 콘솔 — 라이트 커머스 콘솔 (마켓플러스 참고) */
:root{
  --bg:#eef0f3; --surface:#ffffff; --surface2:#f7f8fa;
  --line:#e6e8ec; --line2:#d9dce1;
  --ink:#20242c; --text:#2b313b; --muted:#69707c; --dim:#99a0ab;
  --gold:#a87f33; --gold-bright:#c19a45; --gold-soft:rgba(168,127,51,.10);
  --blue:#2f6fed; --amber:#d9920a; --teal:#0d9aa0; --green:#1aa05a;
  --gray:#6b7280; --violet:#7c5cff; --red:#dc3a3a; --jade:#1aa05a;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,Consolas,monospace;
  --sans:"Pretendard",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --shadow:0 1px 2px rgba(20,28,45,.04),0 2px 8px rgba(20,28,45,.05);
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
code{font-family:var(--mono);font-size:.88em;color:var(--gold);background:var(--gold-soft);padding:1px 6px;border-radius:4px}
h1,h2{margin:0;font-weight:700;letter-spacing:-.01em;color:var(--ink)}

/* ── 셸: 좌측 레일 + 메인 ── */
.shell{display:flex;min-height:100vh}
.rail{flex:0 0 232px;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{padding:24px 24px 20px;border-bottom:1px solid var(--line)}
.brand-mark{color:var(--gold);font-size:15px}
.brand-name{font-size:20px;font-weight:800;letter-spacing:.01em;margin-left:6px;color:var(--ink)}
.brand-name em{font-style:normal;color:var(--gold);font-weight:400}
.brand-sub{display:block;margin-top:6px;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim)}
.nav{padding:14px 12px;display:flex;flex-direction:column;gap:2px;flex:1}
.nav a{position:relative;padding:11px 16px;border-radius:9px;color:var(--muted);font-size:14px;font-weight:500;
  transition:color .15s,background .15s}
.nav a:hover{color:var(--ink);background:var(--surface2)}
.nav a.on{color:var(--gold);background:var(--gold-soft);font-weight:600}
.nav a.on::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:18px;
  background:var(--gold);border-radius:0 3px 3px 0}
.rail-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.who{font-size:12px;color:var(--muted)}
.who::before{content:"●";color:var(--jade);font-size:8px;margin-right:6px;vertical-align:middle}
.logout{font-size:12px;color:var(--dim)}
.logout:hover{color:var(--red)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ── 다크 상단 탭바 ── */
.topbar{display:flex;align-items:center;gap:0;background:#1b1e26;padding:0 26px;min-height:54px;border-bottom:1px solid #10121a}
.crumb{font-size:13px;color:#98a0ad;white-space:nowrap}
.crumb b{color:#fff;font-weight:600}
.crumb .sep{margin:0 8px;color:#535a67}
.topnav{display:flex;gap:2px;height:54px;margin-left:20px;padding-left:20px;border-left:1px solid #2c313c}
.topnav a{display:flex;align-items:center;padding:0 18px;font-size:13.5px;color:#aab0bb;border-bottom:2px solid transparent;transition:color .15s}
.topnav a:hover{color:#fff}
.topnav a.on{color:#fff;border-bottom-color:var(--gold);font-weight:600}
.clock{margin-left:auto;font-family:var(--mono);font-size:12px;color:#6b7280;font-variant-numeric:tabular-nums;white-space:nowrap}

/* ── 2단 그리드 / 미니 통계 ── */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.twocol .panel{margin-bottom:0}
.kpis.half{grid-template-columns:1fr 1fr}
.sub-h{font-size:13px;color:var(--muted);font-weight:600;margin:22px 0 12px}
.bars{display:flex;align-items:flex-end;gap:12px;height:160px;padding:0 4px}
.bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}
.bar-track{flex:1;width:100%;display:flex;align-items:flex-end;background:var(--surface2);border-radius:6px 6px 0 0;overflow:hidden}
.bar-fill{width:100%;background:linear-gradient(180deg,var(--gold-bright),var(--gold));border-radius:6px 6px 0 0;min-height:3px}
.bar-x{font-size:11px;color:var(--dim);font-family:var(--mono)}
.bar-v{font-size:11px;color:var(--muted);font-family:var(--mono);font-variant-numeric:tabular-nums}
.btn-line{padding:10px 16px;border:1px solid var(--line2);border-radius:9px;font-size:13px;color:var(--text);background:var(--surface2);transition:border-color .15s,color .15s}
.btn-line:hover{border-color:var(--gold);color:var(--gold)}
.tbl.info{max-width:560px}
.tbl.info th{text-transform:none;letter-spacing:0;font-size:13px;color:var(--muted);width:140px;font-weight:500;border-bottom:1px solid var(--line)}
.tbl.info td{color:var(--text)}

/* ── 마켓상품관리 리스트 (ms2 스타일) ── */
.filterbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.fchip{padding:9px 16px;border:1px solid var(--line2);border-radius:9px;background:var(--surface);font-size:13px;color:var(--muted);box-shadow:var(--shadow)}
.fchip b{color:var(--ink);font-weight:700;font-family:var(--mono);margin-left:4px}
.fchip:hover{border-color:var(--gold)}
.fchip.on{border-color:var(--gold);color:var(--gold);background:var(--gold-soft)}
.fchip.on b{color:var(--gold)}
.ptbl td{vertical-align:middle}
.pthumb{width:52px}
.pthumb img{width:42px;height:42px;object-fit:cover;border-radius:8px;border:1px solid var(--line);background:var(--surface2)}
.pthumb .noimg{display:block;width:42px;height:42px;border-radius:8px;background:var(--surface2);border:1px solid var(--line)}
.pname{font-weight:500;color:var(--ink);max-width:340px}
.tag{display:inline-block;font-size:11.5px;padding:3px 9px;border-radius:6px;font-weight:600}
.tag.on,.tag.sell{color:var(--green);background:rgba(26,160,90,.1)}
.tag.off,.tag.wait{color:var(--muted);background:var(--surface2);border:1px solid var(--line2)}
.rowbtn{display:inline-block;padding:5px 13px;border:1px solid var(--line2);border-radius:7px;font-size:12px;color:var(--text);background:var(--surface)}
.rowbtn:hover{border-color:var(--gold);color:var(--gold)}
.srcmall{display:inline-block;font-size:11.5px;padding:2px 8px;border-radius:6px;background:rgba(47,111,237,.1);color:var(--blue);font-weight:600}


/* ── 마켓 설정 / 액션 ── */
.btn-go{padding:11px 22px;border:none;border-radius:9px;background:linear-gradient(180deg,var(--gold-bright),var(--gold));color:#fff;font-size:13.5px;font-weight:700;cursor:pointer}
.btn-go:hover{filter:brightness(1.05)}
.flash{padding:13px 16px;border-radius:10px;font-size:13.5px;margin-bottom:18px;font-weight:500}
.flash.ok{background:rgba(26,160,90,.1);border:1px solid rgba(26,160,90,.35);color:var(--green)}
.flash.bad{background:rgba(220,58,58,.08);border:1px solid rgba(220,58,58,.35);color:var(--red)}
.back{display:inline-block;margin-top:6px;font-size:13px;color:var(--muted)}
.back:hover{color:var(--gold)}

.content{padding:30px 36px;max-width:1180px;width:100%}

/* ── 페이지 헤더 ── */
.ph{margin-bottom:24px}
.ph h1{font-size:26px}
.ph p{margin:7px 0 0;color:var(--muted);font-size:13px}

/* ── 패널 ── */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:22px 24px;margin-bottom:18px;box-shadow:var(--shadow)}
.panel-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.panel-head h2{font-size:16px}
.panel-head .conn{font-size:12px;color:var(--muted)}
.panel-head .open{margin-left:auto;font-size:12.5px;color:var(--gold);font-weight:600}
.panel-head .open:hover{color:var(--gold-bright)}
.dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:middle}
.dot.ok{background:var(--jade);box-shadow:0 0 0 3px rgba(26,160,90,.14)}
.dot.bad{background:var(--red);box-shadow:0 0 0 3px rgba(220,58,58,.14)}

/* ── 운영현황 (주문 상태 파이프라인) ── */
.opgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.opgrid.claim{grid-template-columns:repeat(3,1fr);margin-top:12px}
.opcard{position:relative;background:var(--surface2);border:1px solid var(--line);border-radius:11px;
  padding:18px 18px;display:flex;flex-direction:column;gap:9px;overflow:hidden}
.opcard::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--gray)}
.op-num{font-family:var(--mono);font-size:28px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;color:var(--ink)}
.op-lab{font-size:12.5px;color:var(--muted);font-weight:500}
.st-blue::before{background:var(--blue)} .st-blue .op-num{color:var(--blue)}
.st-amber::before{background:var(--amber)} .st-amber .op-num{color:var(--amber)}
.st-teal::before{background:var(--teal)} .st-teal .op-num{color:var(--teal)}
.st-green::before{background:var(--green)} .st-green .op-num{color:var(--green)}
.st-gray::before{background:var(--gray)} .st-gray .op-num{color:var(--gray)}
.st-violet::before{background:var(--violet)} .st-violet .op-num{color:var(--violet)}
.st-red::before{background:var(--red)} .st-red .op-num{color:var(--red)}

/* ── KPI ── */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.kpi{background:var(--surface2);border:1px solid var(--line);border-radius:11px;padding:18px;display:flex;flex-direction:column;gap:10px}
.kpi-eyebrow{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.kpi-num{font-family:var(--mono);font-size:29px;font-weight:700;line-height:1;font-variant-numeric:tabular-nums;color:var(--ink)}
.kpi.gold .kpi-num{color:var(--gold)}
.kpi.won .kpi-num::before{content:"₩";font-size:18px;color:var(--gold);margin-right:2px;vertical-align:top}
.kpi.alert{border-color:rgba(220,58,58,.3)}
.kpi.alert .kpi-num{color:var(--red)}

/* ── 칩 / 상태 ── */
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{font-size:12.5px;padding:7px 14px;border-radius:999px;border:1px solid var(--line2);color:var(--muted);background:var(--surface2)}
.chip.s-available{border-color:rgba(47,111,237,.35);color:var(--blue);background:rgba(47,111,237,.06)}
.chip.s-spec{border-color:rgba(168,127,51,.4);color:var(--gold);background:var(--gold-soft)}
.chip.s-broker{border-color:var(--line2);color:var(--muted)}

/* ── 테이블 ── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line2);color:var(--dim);font-weight:600;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.tbl td{padding:12px 12px;border-bottom:1px solid var(--line);color:var(--text)}
.tbl tr:last-child td{border-bottom:none}
.tbl .mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.tbl .dim{color:var(--dim);font-size:12px}
.mkt .mkt-name{font-weight:600;color:var(--ink)}
.state{font-size:12px;padding:4px 11px;border-radius:6px;border:1px solid var(--line2);color:var(--muted)}
.state.avail{color:var(--blue);border-color:rgba(47,111,237,.3);background:rgba(47,111,237,.07)}
.state.wait{color:var(--gold);border-color:rgba(168,127,51,.35);background:var(--gold-soft)}
.state.broker{color:var(--muted)}

.empty,.note{color:var(--muted);font-size:13px;margin:10px 0 0}
.note a,.note b{color:var(--gold)} .note b{font-weight:600}
.steps{margin:0;padding-left:20px;color:var(--muted);font-size:13.5px;line-height:2}
.steps b{color:var(--ink)}
.deeplinks .links{display:flex;gap:10px;flex-wrap:wrap}
.deeplinks .links a{padding:10px 16px;border:1px solid var(--line2);border-radius:9px;font-size:13px;color:var(--text);background:var(--surface2);transition:border-color .15s,color .15s}
.deeplinks .links a:hover{border-color:var(--gold);color:var(--gold)}

/* ── 로그인 ── */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(900px 480px at 50% -10%,var(--gold-soft),transparent),var(--bg)}
.login{width:344px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:38px 34px;
  display:flex;flex-direction:column;gap:14px;box-shadow:0 20px 50px rgba(20,28,45,.12)}
.login-brand{font-size:26px;font-weight:800;letter-spacing:.01em;text-align:center;color:var(--ink)}
.login-brand em{font-style:normal;color:var(--gold);font-weight:400}
.login-brand .brand-mark{color:var(--gold)}
.login-sub{text-align:center;margin:-8px 0 10px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--dim)}
.login label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--muted)}
.login input{background:var(--surface2);border:1px solid var(--line2);border-radius:9px;padding:12px 14px;color:var(--ink);font-size:14px;font-family:var(--sans)}
.login input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft);background:#fff}
.login button{margin-top:8px;padding:13px;border:none;border-radius:9px;background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  color:#fff;font-size:14px;font-weight:700;cursor:pointer;letter-spacing:.02em}
.login button:hover{filter:brightness(1.05)}
.login-err{background:rgba(220,58,58,.08);border:1px solid rgba(220,58,58,.3);color:var(--red);
  font-size:12.5px;padding:10px 12px;border-radius:8px;text-align:center}

a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

/* ── 반응형 ── */
@media (max-width:880px){
  .shell{flex-direction:column}
  .rail{flex:none;width:100%;height:auto;position:static;flex-direction:row;flex-wrap:wrap;align-items:center}
  .brand{border-bottom:none;border-right:1px solid var(--line);padding:16px 20px}
  .brand-sub{display:none}
  .nav{flex-direction:row;flex-wrap:wrap;flex:1;padding:10px}
  .nav a.on::before{display:none}
  .rail-foot{border-top:none;width:auto}
  .kpis,.opgrid,.opgrid.claim,.kpis.half,.twocol{grid-template-columns:repeat(2,1fr)}
  .twocol{grid-template-columns:1fr}
  .topnav{overflow-x:auto}
  .topbar{padding:0 14px;flex-wrap:wrap;min-height:auto}
  .topnav{margin-left:0;padding-left:0;border-left:none}
  .content{padding:20px 16px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ── 마켓 보내기/가져오기 툴바 (v2) ── */
.ptoolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding:11px 14px;background:var(--surface);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow)}
.selall{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px;cursor:pointer}
.msel{padding:8px 12px;border:1px solid var(--line2);border-radius:8px;background:var(--surface2);font-size:13px;color:var(--ink)}
.btn-go.sm,.btn-line.sm{padding:8px 16px;font-size:13px}
.tbnote{margin-left:auto;font-size:12px}
.ck{width:34px;text-align:center}
.vend{display:inline-block;font-size:12px;color:var(--text);background:var(--surface2);border:1px solid var(--line2);padding:2px 8px;border-radius:6px}

.chip.s-connected{border-color:rgba(26,160,90,.4);color:var(--green);background:rgba(26,160,90,.08)}
.rowbtn.on{border-color:var(--gold);color:var(--gold);background:var(--gold-soft)}

.state.ok{color:var(--green);border-color:rgba(26,160,90,.3);background:rgba(26,160,90,.08)}
