@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap);:root{--bg:#f4f6f9;--bg2:#fff;--bg3:#f0f2f5;--border:#dde1e7;--border2:#c8cdd6;--navy:#1b2a4a;--gold:#b07820;--gold-light:#92400e;--blue:#1a56a8;--blue-light:#1a56a8;--green:#0d6b3c;--green-light:#15803d;--red:#c0392b;--red-light:#991b1b;--white:#1a1f2e;--muted:#6b7280;--muted2:#9ca3af;--code:#1a56a8;--neg:#c0392b;--font-display:"Inter",sans-serif;--font-body:"Inter",sans-serif;--font-mono:"DM Mono",monospace}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;background:#f4f6f9;background:var(--bg);color:#1a1f2e;color:var(--white);font-family:Inter,sans-serif;font-family:var(--font-body);font-size:15px;line-height:1.6}.app-header{background:#1b2a4a;background:var(--navy);border-bottom:1px solid #ffffff14;position:sticky;top:0;z-index:100}.app-header__inner{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 32px}.app-header__brand{align-items:baseline;display:flex;gap:10px}.app-header__hc{color:#fff;font-family:Inter,sans-serif;font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:.5px}.app-header__admin{color:#ffffff8c;font-size:13px;font-weight:400;letter-spacing:.5px}.app-header__meta{align-items:center;display:flex;gap:16px}.app-header__refresh{color:#ffffff73;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:12px}.app-header__btn{background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:13px;font-weight:600;padding:7px 16px;transition:all .15s}.app-header__btn:hover{background:#fff3}.app-main{margin:0 auto;max-width:1400px;padding:28px 32px 64px}.stats-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.stat-card{background:#fff;background:var(--bg2);border:1px solid #dde1e7;border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 3px #0000000f;overflow:hidden;padding:20px 24px;position:relative}.stat-card:before{border-radius:10px 10px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card--blue:before{background:#1a56a8;background:var(--blue)}.stat-card--gold:before{background:#c8922a}.stat-card--green:before{background:#0d6b3c;background:var(--green)}.stat-card--muted:before{background:#c8cdd6;background:var(--border2)}.stat-card__value{color:#1b2a4a;color:var(--navy);font-size:32px;font-weight:700;letter-spacing:-.5px;line-height:1;margin-bottom:6px}.stat-card__label{color:#6b7280;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.8px;text-transform:uppercase}.stat-card__sub{color:#9ca3af;color:var(--muted2);font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:11px;margin-top:4px}.section{background:#fff;background:var(--bg2);border:1px solid #dde1e7;border:1px solid var(--border);border-radius:10px;box-shadow:0 1px 3px #0000000f;margin-bottom:24px;overflow:hidden}.section__desc{color:#6b7280;color:var(--muted);font-size:13px;padding:0 24px 14px}.section-header,.section__desc{border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border)}.section-header{align-items:center;display:flex;justify-content:space-between;padding:16px 24px}.section-header__left{align-items:center;display:flex;gap:10px}.section-header__title{color:#1b2a4a;color:var(--navy);font-size:16px;font-weight:700;letter-spacing:.1px}.section-header__count{background:#f0f2f5;background:var(--bg3);border:1px solid #dde1e7;border:1px solid var(--border);border-radius:20px;color:#1b2a4a;color:var(--navy);font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:11px;font-weight:600;padding:2px 8px}.refresh-btn{background:none;border:none;border-radius:4px;color:#9ca3af;color:var(--muted2);cursor:pointer;display:inline-block;font-size:18px;padding:4px 8px;transition:all .15s}.refresh-btn:hover{color:#1b2a4a;color:var(--navy)}.refresh-btn--spinning{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table thead tr{background:#f0f2f5;background:var(--bg3)}.data-table th{border-bottom:2px solid #dde1e7;border-bottom:2px solid var(--border);color:#6b7280;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.8px;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table th.num{text-align:right}.data-row{border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.data-row:hover{background:#f8f9fb}.data-row--expanded{background:#eef4ff}.data-table td{color:#1a1f2e;color:var(--white);font-size:14px;padding:12px 16px;vertical-align:middle}.data-table td.num{font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:13px;text-align:right}.data-table td.bold{font-weight:600}.data-table td.muted{color:#6b7280;color:var(--muted);font-size:13px}.data-table td.neg{color:#c0392b;color:var(--neg);font-weight:600}.product-name{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.code-badge{background:#eef2ff;border:1px solid #c7d2fe;border-radius:4px;color:#1e40af;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:12px;font-weight:500;padding:3px 8px;white-space:nowrap}.code-badge--sm{font-size:11px;padding:2px 6px}.pill{border-radius:20px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.4px;padding:3px 10px;text-transform:uppercase;white-space:nowrap}.pill--blue{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.pill--green{background:#dcfce7;border:1px solid #bbf7d0;color:#15803d}.pill--gold{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.pill--red{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.pill--muted{background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280}.detail-row td{background:#f8fafc;padding:0}.detail-wrap{border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);border-top:1px solid #dde1e7;border-top:1px solid var(--border);padding:16px 24px 20px 48px}.detail-title{color:#92400e;font-size:11px;font-weight:700;letter-spacing:.8px;margin-bottom:12px;text-transform:uppercase}.detail-table{border-collapse:collapse;width:100%}.detail-table th{border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);color:#6b7280;color:var(--muted);font-size:11px;font-weight:600;letter-spacing:.6px;padding:6px 12px;text-align:left;text-transform:uppercase}.detail-table th.num{text-align:right}.detail-table td{border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);color:#1a1f2e;color:var(--white);font-size:13px;padding:9px 12px}.detail-table td.num{font-family:DM Mono,monospace;font-family:var(--font-mono);text-align:right}.detail-table td.bold{font-weight:600}.order-line{border:1px solid #dde1e7;border:1px solid var(--border);border-radius:8px;margin-bottom:10px;overflow:hidden}.order-line__header{align-items:center;background:#f0f2f5;background:var(--bg3);display:flex;gap:12px;padding:10px 14px}.order-line__name{color:#1a1f2e;color:var(--white);flex:1 1;font-size:14px;font-weight:500}.order-line__qty{color:#6b7280;color:var(--muted);font-size:13px}.order-line__qty strong{color:#1a1f2e;color:var(--white);font-weight:600}.order-line__cost{color:#92400e;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:13px;font-weight:600}.order-line__links{background:#fff;background:var(--bg2);display:flex;flex-wrap:wrap;gap:8px;padding:8px 14px}.fulfil-link{align-items:center;background:#eef2ff;border:1px solid #c7d2fe;border-radius:4px;display:flex;gap:6px;padding:4px 10px}.fulfil-link__ref{color:#1e40af;font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:12px;font-weight:500}.fulfil-link__qty{color:#6b7280;color:var(--muted);font-size:12px}.empty-row,.loading-row{color:#6b7280;color:var(--muted);font-size:14px;padding:32px 24px;text-align:center}.empty-row{color:#15803d;font-weight:500}.detail-loading{color:#6b7280;color:var(--muted);font-size:13px;font-style:italic;padding:12px 24px}.app-footer{background:#fff;background:var(--bg2);border-top:1px solid #dde1e7;border-top:1px solid var(--border);color:#9ca3af;color:var(--muted2);font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:12px;padding:24px;text-align:center}@media (max-width:900px){.stats-row{grid-template-columns:repeat(2,1fr)}.app-main{padding:20px 16px 48px}}@media (max-width:500px){.stats-row{grid-template-columns:1fr}}.so-group{border:1px solid #dde1e7;border:1px solid var(--border);border-radius:8px;margin-bottom:10px;overflow:hidden}.so-group__header{align-items:center;background:#f0f2f5;background:var(--bg3);border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:10px 14px}.so-group__customer{color:#1a1f2e;color:var(--white);flex:1 1;font-size:14px;font-weight:600}.so-group__items{background:#fff;background:var(--bg2);padding:4px 0}.so-item{align-items:center;border-bottom:1px solid #dde1e7;border-bottom:1px solid var(--border);display:flex;gap:10px;padding:8px 14px}.so-item:last-child{border-bottom:none}.so-item__name{color:#1a1f2e;color:var(--white);flex:1 1;max-width:400px;overflow:hidden;text-overflow:ellipsis}.so-item__name,.so-item__qty{font-size:13px;white-space:nowrap}.so-item__qty{color:#6b7280;color:var(--muted)}.so-item__qty strong{color:#1a1f2e;color:var(--white);font-weight:600}.qty-ok{color:#15803d!important}.qty-ok,.qty-short{font-weight:600!important}.qty-short{color:#991b1b!important}.so-item__dot{flex-shrink:0;font-size:10px}.so-item__dot--green{color:#15803d}.so-item__dot--red{color:#991b1b}.so-item__po-hint{color:#9ca3af;color:var(--muted2);font-family:DM Mono,monospace;font-family:var(--font-mono);font-size:11px;margin-left:4px}.so-item--cancelled{opacity:.45}.so-item--cancelled .so-item__name{color:#6b7280;color:var(--muted);text-decoration:line-through}.so-item--cancelled .code-badge{opacity:.6}.ignore-btn{background:#fee2e2;border:1px solid #fecaca;border-radius:4px;color:#991b1b;cursor:pointer;flex-shrink:0;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:11px;font-weight:700;margin-left:auto;padding:4px 10px;transition:all .15s;white-space:nowrap}.ignore-btn:hover:not(:disabled){background:#fecaca;border-color:#f87171}.ignore-btn:disabled{cursor:not-allowed;opacity:.4}.ignore-btn--restore{background:#dcfce7;border:1px solid #bbf7d0;color:#15803d}.ignore-btn--restore:hover:not(:disabled){background:#bbf7d0;border-color:#4ade80}.action-btn{border-radius:6px;cursor:pointer;flex-shrink:0;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:12px;font-weight:600;padding:5px 14px;transition:all .15s;white-space:nowrap}.action-btn:disabled{cursor:not-allowed;opacity:.4}.action-btn--close{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.action-btn--close:hover:not(:disabled){background:#fde68a}.action-btn--close:disabled{background:#f9fafb;border-color:#dde1e7;border-color:var(--border);color:#9ca3af;color:var(--muted2);opacity:.5}.action-btn--reset{background:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.action-btn--reset:hover:not(:disabled){background:#bfdbfe}.action-btn--ghost{background:#f0f2f5;background:var(--bg3);border:1px solid #dde1e7;border:1px solid var(--border);color:#6b7280;color:var(--muted)}.action-btn--ghost:hover{background:#e8edf4;border-color:#1b2a4a;border-color:var(--navy);color:#1b2a4a;color:var(--navy)}.action-btn--active{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.action-btn--active:hover{background:#fde68a}.section-header__right{align-items:center;display:flex;gap:8px}.note-input{background:#f0f2f5;background:var(--bg3);border:1px solid #dde1e7;border:1px solid var(--border);border-radius:4px;color:#1a1f2e;color:var(--white);flex-shrink:0;font-family:Inter,sans-serif;font-family:var(--font-body);font-size:12px;outline:none;padding:4px 10px;transition:all .15s;width:200px}.note-input::placeholder{color:#9ca3af;color:var(--muted2);font-style:italic}.note-input:focus{background:#fff;background:var(--bg2);border-color:#1a56a8;border-color:var(--blue);box-shadow:0 0 0 3px #1a56a81a}.note-input--saving{opacity:.5}
/*# sourceMappingURL=main.62565f27.css.map*/