:root{
  --kurly:#5f0080; --kurly-2:#7c3aed; --bg:#f6f5f8; --line:#e6e3ec;
  --txt:#2b2336; --muted:#8b8496; --ok:#2e7d32; --warn:#c62828;
}
*{box-sizing:border-box}
body{margin:0;font-family:"Malgun Gothic","맑은 고딕",system-ui,sans-serif;background:var(--bg);color:var(--txt)}
a{text-decoration:none;color:inherit}

/* ---- topbar ---- */
.topbar{display:flex;align-items:center;gap:24px;background:var(--kurly);color:#fff;padding:0 20px;height:56px}
.brand{font-weight:800;font-size:17px;display:flex;align-items:center;gap:8px}
.badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:700}
.badge.mock{background:#ffe08a;color:#7a5a00}
.badge.live{background:#b9f6ca;color:#1b5e20}
.mainnav{display:flex;gap:4px;flex:1}
.mainnav a{padding:8px 14px;border-radius:8px;font-weight:600;opacity:.85}
.mainnav a:hover{background:rgba(255,255,255,.15);opacity:1}
.mainnav a.on{background:#fff;color:var(--kurly);opacity:1}
.userbox{display:flex;align-items:center;gap:12px;font-size:13px}
.logout{background:rgba(255,255,255,.18);padding:6px 12px;border-radius:8px}

.content{max-width:1180px;margin:24px auto;padding:0 20px 60px}
.page-title{font-size:22px;margin:0 0 16px}
.sub-title{margin:28px 0 10px;font-size:16px;color:var(--kurly)}
.foot{text-align:center;color:var(--muted);font-size:12px;padding:20px}
.muted{color:var(--muted);font-size:13px}

/* ---- flash / errors ---- */
.flash{background:#ede7f6;border:1px solid #d1c4e9;color:#4527a0;padding:10px 14px;border-radius:8px;margin-bottom:16px}
.errbox{background:#fff3f3;border:1px solid #ffcdd2;color:#b71c1c;padding:12px 16px;border-radius:8px;margin-bottom:16px}
.errbox ul{margin:8px 0 0;padding-left:20px}
.err{color:var(--warn)}

/* ---- cards ---- */
.cards{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;margin-bottom:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;text-align:center}
.card .num{font-size:26px;font-weight:800}
.card .lbl{font-size:12px;color:var(--muted);margin-top:4px}
.c-ready{border-top:3px solid #90a4ae}.c-prog{border-top:3px solid #7c3aed}
.c-ship{border-top:3px solid #1976d2}.c-done{border-top:3px solid var(--ok)}
.c-cancel{border-top:3px solid #9e9e9e}.c-fail{border-top:3px solid var(--warn)}

.panel-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.panel{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px}
.panel h3{margin:0 0 12px}
table.kv{width:100%;border-collapse:collapse}
table.kv td{padding:7px 4px;border-bottom:1px dashed var(--line);font-size:14px}
table.kv td.r{text-align:right;font-weight:700}

.quick{display:flex;gap:10px;margin-top:18px}

/* ---- buttons ---- */
.btn{display:inline-block;background:var(--kurly);color:#fff;border:0;border-radius:8px;
  padding:9px 16px;font-size:14px;font-weight:700;cursor:pointer}
.btn:hover{background:#4a0066}
.btn.ghost{background:#fff;color:var(--kurly);border:1px solid var(--kurly)}
.btn.danger{background:var(--warn)}
.btn.sm{padding:6px 12px;font-size:13px}

/* ---- toolbar/filters ---- */
.toolbar{display:flex;align-items:center;gap:10px;margin:14px 0;flex-wrap:wrap}
.inline{display:inline-flex;gap:8px;align-items:center}
.filters{display:flex;gap:8px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:12px;margin-bottom:12px}
.filters input,.filters select,.vform input{padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.filters input[name=keyword]{min-width:280px}

/* ---- grid table ---- */
table.grid{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
table.grid th{background:#f3effa;color:#4a3b66;font-size:13px;padding:10px 8px;text-align:left;border-bottom:1px solid var(--line)}
table.grid td{padding:9px 8px;border-bottom:1px solid #f0eef4;font-size:13px;vertical-align:top}
table.grid tr:hover td{background:#faf8fe}
.addr{max-width:220px;color:#555}
.empty{text-align:center;color:var(--muted);padding:30px}

/* status chips */
.st{padding:2px 8px;border-radius:10px;font-size:12px;font-weight:700;white-space:nowrap}
.st-출고대기{background:#eceff1;color:#455a64}
.st-출고진행중{background:#ede7f6;color:#5e35b1}
.st-배송중{background:#e3f2fd;color:#1565c0}
.st-배송완료{background:#e8f5e9;color:#2e7d32}
.st-주문취소{background:#f5f5f5;color:#757575}
.st-배송실패{background:#ffebee;color:#c62828}

/* ---- vform ---- */
.vform{display:flex;flex-direction:column;gap:6px}
.vform label{font-size:13px;color:var(--muted);margin-top:6px}
.vform .btn{margin-top:12px}

/* ---- login ---- */
.login-bg{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:linear-gradient(135deg,#5f0080,#9b59b6)}
.login-card{background:#fff;border-radius:16px;padding:40px;width:360px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.login-card h1{margin:0;color:var(--kurly);font-size:24px;line-height:1.3}
.login-card .sub{color:var(--muted);margin:6px 0 20px;font-size:14px}
.login-card label{display:block;font-size:13px;color:var(--muted);margin:10px 0 4px}
.login-card input{width:100%;padding:11px;border:1px solid var(--line);border-radius:8px;font-size:15px}
.login-card button{width:100%;margin-top:20px;padding:12px;background:var(--kurly);color:#fff;border:0;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer}
.login-card .hint{font-size:12px;color:var(--muted);margin-top:18px;line-height:1.6}
.login-error{background:#ffebee;color:#c62828;padding:10px;border-radius:8px;font-size:13px;margin-bottom:8px}
