:root{--bg: #f6f7fb;--surface: #ffffff;--surface-2: #f1f3f8;--border: #e3e6ee;--text: #1d2233;--text-mute: #6b7388;--text-faint: #98a0b3;--primary: #4f46e5;--primary-hover: #4338ca;--primary-soft: #eef0ff;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--radius-sm: 6px;--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow: 0 6px 24px rgba(15, 23, 42, .08);--shadow-lg: 0 24px 60px rgba(15, 23, 42, .16);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font-12: 12px;--font-13: 13px;--font-14: 14px;--font-16: 16px;--font-18: 18px;--font-22: 22px;--ease: cubic-bezier(.2, .8, .2, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;overflow:hidden}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--font-14);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:var(--font-14);color:var(--text)}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;font-size:var(--font-13);font-weight:600;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);color:var(--text);transition:background .18s var(--ease),border-color .18s var(--ease),opacity .18s var(--ease);white-space:nowrap}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn.primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn.danger{color:var(--danger);border-color:#fbd5d5;background:#fff5f5}.btn.ghost{background:transparent;border:none}.btn.sm{padding:6px 10px;font-size:var(--font-12)}.btn.icon{width:32px;height:32px;padding:0}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.field{display:flex;flex-direction:column;gap:6px}.field>label{font-size:var(--font-12);color:var(--text-mute);font-weight:600}.input{height:38px;padding:0 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);outline:none;transition:border-color .18s var(--ease),box-shadow .18s var(--ease);width:100%}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e526}.input.num-money{text-align:right}.input.num-plain{text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;animation:fadeIn .2s var(--ease) forwards}.modal-panel{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:min(560px,calc(100vw - 40px));max-height:calc(100vh - 64px);display:flex;flex-direction:column;transform:translateY(8px);opacity:0;animation:panelIn .22s var(--ease) forwards}.modal-head,.modal-foot{padding:16px 22px;display:flex;align-items:center}.modal-head{justify-content:space-between;border-bottom:1px solid var(--border)}.modal-foot{justify-content:flex-end;gap:8px;border-top:1px solid var(--border)}.modal-body{padding:22px;overflow:auto}.modal-title{font-size:var(--font-16);font-weight:700}@keyframes fadeIn{to{opacity:1}}@keyframes panelIn{to{opacity:1;transform:translateY(0)}}.tbl-wrap{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;flex:1 1 0;min-height:0;overflow:hidden}.tbl-scroll{flex:1 1 0;overflow:auto;min-height:0}.tbl{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed}.tbl thead th{position:sticky;top:0;background:var(--surface-2);font-size:var(--font-12);font-weight:700;color:var(--text-mute);text-align:center;padding:10px 8px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);white-space:nowrap;z-index:1}.tbl thead th:last-child{border-right:none}.tbl tbody td{height:44px;padding:0 8px;text-align:center;border-bottom:1px solid var(--border);border-right:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--font-13)}.tbl tbody td:last-child{border-right:none}.tbl tbody tr.empty td{color:transparent;border-right-color:transparent}.tbl tbody td.money{text-align:right;padding-right:14px}.tbl tbody tr:hover:not(.empty){background:#fafbff}.cell-ellipsis{position:relative;display:inline-block;max-width:100%;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%) translateY(4px);background:#111827;color:#fff;padding:6px 10px;border-radius:6px;font-size:var(--font-12);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .16s var(--ease),transform .16s var(--ease);z-index:5}.cell-ellipsis.truncated:hover .tip{opacity:1;transform:translate(-50%) translateY(0)}.pagination{display:flex;justify-content:center;align-items:center;gap:4px;padding:10px;border-top:1px solid var(--border)}.pagination button{width:28px;height:28px;border-radius:6px;font-size:var(--font-12);color:var(--text-mute)}.pagination button:hover{background:var(--surface-2)}.pagination button.active{background:var(--primary);color:#fff}.pagination button:disabled{opacity:.4;cursor:not-allowed}.toggle{width:36px;height:20px;border-radius:999px;background:#cbd1de;position:relative;transition:background .18s var(--ease);display:inline-block}.toggle:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;left:2px;transition:left .18s var(--ease);box-shadow:var(--shadow-sm)}.toggle.on{background:var(--success)}.toggle.on:after{left:18px}.icon-btn{display:inline-flex;width:28px;height:28px;align-items:center;justify-content:center;border-radius:6px;color:var(--text-mute);transition:background .16s var(--ease),color .16s var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.danger:hover{color:var(--danger);background:#fff1f1}.combo{position:relative}.combo-list{position:absolute;left:0;right:0;top:calc(100% + 4px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow);max-height:240px;overflow:auto;z-index:50}.combo-opt{padding:8px 12px;font-size:var(--font-13);cursor:pointer}.combo-opt:hover,.combo-opt.active{background:var(--primary-soft);color:var(--primary)}.dp{position:relative}.dp-pop{position:absolute;z-index:50;top:calc(100% + 4px);left:0;width:280px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:6px}.dp-head select{height:28px;border-radius:6px;border:1px solid var(--border);padding:0 4px;background:var(--surface)}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-cell{height:32px;display:flex;align-items:center;justify-content:center;font-size:var(--font-12);border-radius:6px;cursor:pointer}.dp-cell.dow{color:var(--text-faint);cursor:default}.dp-cell.muted{color:var(--text-faint)}.dp-cell:hover:not(.dow){background:var(--surface-2)}.dp-cell.sel{background:var(--primary);color:#fff}.skel{background:linear-gradient(90deg,#eef0f5,#f6f7fb,#eef0f5);background-size:200% 100%;animation:skel 1.2s infinite;border-radius:6px}@keyframes skel{0%{background-position:200% 0}to{background-position:-200% 0}}.app-shell{display:flex;height:100vh}.sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}.sidebar .logo{padding:18px 22px;font-weight:800;font-size:var(--font-18);color:var(--primary);letter-spacing:-.02em;cursor:pointer}.sidebar nav{padding:4px 10px;display:flex;flex-direction:column;gap:2px;overflow:auto}.sidebar nav .nav-title{font-size:11px;color:var(--text-faint);padding:14px 12px 6px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.sidebar nav a{display:flex;align-items:center;gap:10px;padding:9px 12px;font-size:var(--font-13);font-weight:500;color:var(--text-mute);border-radius:8px;transition:background .16s var(--ease),color .16s var(--ease)}.sidebar nav a:hover{background:var(--surface-2);color:var(--text)}.sidebar nav a.active{background:var(--primary-soft);color:var(--primary)}.sidebar .me{margin-top:auto;padding:14px;border-top:1px solid var(--border);font-size:var(--font-12);color:var(--text-mute);display:flex;align-items:center;gap:8px}.main{flex:1;display:flex;flex-direction:column;min-width:0}.topbar{height:56px;padding:0 24px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;justify-content:space-between}.topbar h1{font-size:var(--font-16);font-weight:700;margin:0}.page{flex:1;min-height:0;padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow:hidden}.page-head{display:flex;justify-content:space-between;align-items:center}.page-head h2{margin:0;font-size:var(--font-18);font-weight:700}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.kpi{padding:16px 18px}.kpi .label{font-size:var(--font-12);color:var(--text-mute)}.kpi .value{font-size:24px;font-weight:700;margin-top:6px}.kpi .sub{font-size:var(--font-12);color:var(--text-faint);margin-top:4px}.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;overflow:auto;padding-right:4px;min-height:0;flex:1}.prod-card{overflow:hidden;display:flex;flex-direction:column;transition:transform .18s var(--ease)}.prod-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.prod-thumb{aspect-ratio:4 / 3;background:var(--surface-2);width:100%;object-fit:cover}.prod-body{padding:12px 14px;display:flex;flex-direction:column;gap:4px}.prod-title{font-size:var(--font-14);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prod-vendor{font-size:var(--font-12);color:var(--text-mute)}.prod-foot{display:flex;align-items:center;justify-content:space-between;padding:0 14px 14px}.prod-price{font-size:var(--font-16);font-weight:700;color:var(--primary)}.auth-shell{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{width:380px;padding:28px 30px}.auth-card h1{margin:0 0 18px;font-size:var(--font-22);color:var(--primary)}.auth-card .field+.field{margin-top:12px}.auth-card .btn{width:100%;margin-top:18px}.auth-link{text-align:center;margin-top:12px;font-size:var(--font-12);color:var(--text-mute)}.auth-link a{color:var(--primary);font-weight:600}.cart-row{display:grid;grid-template-columns:80px 1fr 120px 100px 80px;gap:14px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}.cart-row .thumb{width:64px;height:64px;border-radius:8px;background:var(--surface-2);object-fit:cover}.qty-pill{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;overflow:hidden;height:30px}.qty-pill button{width:28px;height:28px;font-size:var(--font-14);color:var(--text-mute)}.qty-pill input{width:36px;height:28px;border:none;text-align:center;background:transparent}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--text-mute);gap:8px}.m-bg{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:#dde2ee}.m-frame{width:min(440px,100vw);height:min(900px,100vh);background:var(--bg);display:flex;flex-direction:column;box-shadow:0 30px 80px #0f172a38;overflow:hidden;position:relative;border-radius:0}@media (max-width: 480px),(max-height: 900px){.m-bg{background:var(--bg)}.m-frame{width:100vw;height:100vh;box-shadow:none}}.m-top{height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.m-logo{font-weight:800;color:var(--primary);font-size:16px;cursor:pointer;letter-spacing:-.02em}.m-actions{display:flex;gap:6px;align-items:center}.m-iconbtn{width:34px;height:34px;border-radius:10px;background:var(--surface-2);font-size:15px;display:inline-flex;align-items:center;justify-content:center;transition:background .16s var(--ease)}.m-iconbtn:hover{background:var(--border)}.m-loginbtn{padding:7px 14px;border-radius:999px;background:var(--primary);color:#fff;font-size:12px;font-weight:700}.m-body{flex:1;overflow:auto;padding:16px;min-height:0;-webkit-overflow-scrolling:touch}.m-tabs{height:64px;flex-shrink:0;display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--border);background:var(--surface);padding-bottom:env(safe-area-inset-bottom)}.m-tabs a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:11px;font-weight:600;color:var(--text-faint);position:relative;transition:color .16s var(--ease)}.m-tabs a.active{color:var(--primary)}.m-tabico{font-size:19px;line-height:1}.m-badge{position:absolute;top:8px;left:calc(50% + 4px);background:var(--danger);color:#fff;border-radius:999px;font-size:9px;font-weight:700;padding:1px 5px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.m-search{height:40px;border-radius:999px;border:1px solid var(--border);background:var(--surface);padding:0 16px;width:100%;font-size:13px;outline:none;transition:border-color .16s var(--ease),box-shadow .16s var(--ease)}.m-search:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.m-cats{display:flex;gap:6px;overflow-x:auto;margin:12px -16px 14px;padding:0 16px;scrollbar-width:none}.m-cats::-webkit-scrollbar{display:none}.m-chip{flex-shrink:0;padding:7px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:12px;color:var(--text-mute);cursor:pointer;white-space:nowrap;font-weight:600;transition:all .16s var(--ease)}.m-chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}.m-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.m-prod{background:var(--surface);border-radius:14px;overflow:hidden;border:1px solid var(--border);display:flex;flex-direction:column;transition:transform .18s var(--ease),box-shadow .18s var(--ease)}.m-prod:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.m-prod-thumb{aspect-ratio:1 / 1;background:var(--surface-2);object-fit:cover;width:100%}.m-prod-body{padding:10px 12px 4px;display:flex;flex-direction:column;gap:3px}.m-prod-vendor{font-size:10px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.m-prod-name{font-size:13px;font-weight:600;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.35;min-height:35px}.m-prod-foot{display:flex;align-items:center;justify-content:space-between;padding:6px 12px 12px;margin-top:auto}.m-prod-price{font-size:14px;font-weight:800;color:var(--text)}.m-prod-add{width:32px;height:32px;border-radius:10px;background:var(--primary);color:#fff;font-size:18px;display:inline-flex;align-items:center;justify-content:center;transition:background .16s var(--ease),transform .16s var(--ease)}.m-prod-add:hover{background:var(--primary-hover)}.m-prod-add:active{transform:scale(.94)}.m-prod-add:disabled{opacity:.4;cursor:not-allowed}.m-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-mute);gap:10px;text-align:center}.m-empty .ico{font-size:40px;opacity:.5}.m-cart-list{display:flex;flex-direction:column}.m-cart-row{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border);align-items:center}.m-cart-row:last-child{border-bottom:none}.m-cart-thumb{width:64px;height:64px;border-radius:12px;object-fit:cover;flex-shrink:0;background:var(--surface-2)}.m-cart-info{flex:1;min-width:0}.m-cart-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.m-cart-vendor{font-size:11px;color:var(--text-mute);margin-top:2px}.m-cart-priceqty{display:flex;align-items:center;justify-content:space-between;margin-top:8px}.m-cart-price{font-size:13px;color:var(--primary);font-weight:800}.m-qty{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;height:28px;background:var(--surface);overflow:hidden}.m-qty button{width:26px;height:28px;font-size:13px;color:var(--text-mute)}.m-qty button:hover{background:var(--surface-2);color:var(--text)}.m-qty span{width:26px;text-align:center;font-size:12px;font-weight:600}.m-cart-del{margin-left:4px;width:24px;height:24px;border-radius:6px;color:var(--text-faint);font-size:13px;display:inline-flex;align-items:center;justify-content:center}.m-cart-del:hover{background:#fff1f1;color:var(--danger)}.m-checkout{margin-top:16px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px}.m-checkout-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:var(--text-mute)}.m-checkout-total{display:flex;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.m-checkout-total span:last-child{font-size:18px;font-weight:800;color:var(--primary)}.m-checkout button{width:100%;height:48px;border-radius:12px;background:var(--primary);color:#fff;font-size:15px;font-weight:700;margin-top:14px;transition:background .16s var(--ease)}.m-checkout button:hover{background:var(--primary-hover)}.m-checkout button:disabled{opacity:.5;cursor:not-allowed}.m-order{background:var(--surface);border-radius:14px;border:1px solid var(--border);padding:14px 16px;margin-bottom:10px}.m-order-head{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-mute);margin-bottom:8px}.m-order-id{font-family:monospace;font-weight:600}.m-order-items{font-size:13px;color:var(--text);line-height:1.5}.m-order-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:10px;border-top:1px dashed var(--border)}.m-order-total{font-size:15px;font-weight:800;color:var(--primary)}.m-flash{background:#ecfdf5;color:#065f46;padding:12px 14px;border-radius:12px;font-size:12px;font-weight:600;margin-bottom:14px}.m-section-title{font-size:11px;color:var(--text-faint);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}.pill.gray{background:var(--surface-2);color:var(--text-mute)}.pill.blue{background:#eef2ff;color:#4338ca}.pill.green{background:#ecfdf5;color:#065f46}.pill.orange{background:#fff7ed;color:#b45309}.po-sheet{background:#fff;padding:24px;border:1px solid var(--border);border-radius:var(--radius);flex:1;overflow:auto}.po-sheet h3{margin:0 0 8px;font-size:var(--font-18)}.po-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 24px;font-size:var(--font-13);margin-bottom:16px;color:var(--text-mute)}.po-meta b{color:var(--text)}.po-sheet table{width:100%;border-collapse:collapse}.po-sheet th,.po-sheet td{padding:8px;border-bottom:1px solid var(--border);font-size:var(--font-13)}.po-sheet th{background:var(--surface-2);font-weight:600;text-align:left}.po-sheet td.right{text-align:right}.po-sheet tfoot td{font-weight:700;background:var(--surface-2)}
