:root{--bg:#eef1f6;--surface:#fff;--surface-2:#f6f8fb;--border:#e3e8ef;--border-strong:#cfd6e1;--text:#0f1729;--text-muted:#5b6675;--text-subtle:#97a1b0;--primary:#2f6bff;--primary-hover:#1f55e6;--primary-soft:#e8efff;--on-primary:#fff;--accent:#f59e0b;--accent-soft:#fdecc8;--accent-text:#92600a;--success:#16a34a;--success-soft:#dcfce7;--danger:#e1453a;--danger-soft:#fde4e2;--info:#2f6bff;--info-soft:#e8efff;--ring:#2f6bff47;--radius-sm:8px;--radius:12px;--radius-lg:18px;--shadow-sm:0 1px 2px #0f17290f, 0 1px 1px #0f17290a;--shadow-md:0 6px 18px #0f172914;--shadow-lg:0 18px 40px #0f172929;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--mono:ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;--sidebar-w:252px}.dark-tokens,:root[data-theme=dark]{--bg:#0a0f1c;--surface:#111827;--surface-2:#161f31;--border:#243049;--border-strong:#324063;--text:#eef2f8;--text-muted:#9aa6b8;--text-subtle:#8893a6;--primary:#5b8cff;--primary-hover:#6f9bff;--primary-soft:#1a2542;--on-primary:#0a0f1c;--accent:#fbbf24;--accent-soft:#3a2e10;--accent-text:#fcd068;--success:#34d27f;--success-soft:#12301f;--danger:#f87171;--danger-soft:#3a1a18;--info:#5b8cff;--info-soft:#1a2542;--ring:#5b8cff66;--shadow-sm:0 1px 2px #0006;--shadow-md:0 8px 22px #00000073;--shadow-lg:0 20px 44px #0000008c}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--bg:#0a0f1c;--surface:#111827;--surface-2:#161f31;--border:#243049;--border-strong:#324063;--text:#eef2f8;--text-muted:#9aa6b8;--text-subtle:#8893a6;--primary:#5b8cff;--primary-hover:#6f9bff;--primary-soft:#1a2542;--on-primary:#0a0f1c;--accent:#fbbf24;--accent-soft:#3a2e10;--accent-text:#fcd068;--success:#34d27f;--success-soft:#12301f;--danger:#f87171;--danger-soft:#3a1a18;--info:#5b8cff;--info-soft:#1a2542;--ring:#5b8cff66;--shadow-sm:0 1px 2px #0006;--shadow-md:0 8px 22px #00000073;--shadow-lg:0 20px 44px #0000008c}}*,:before,:after{box-sizing:border-box}*{margin:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:14px;line-height:1.5}button{font:inherit;color:inherit;cursor:pointer}input,select{font:inherit;color:inherit}h1,h2,h3{line-height:1.25}:focus-visible{box-shadow:0 0 0 3px var(--ring);border-radius:var(--radius-sm);outline:none}.muted{color:var(--text-muted)}.small{font-size:12.5px}.strong{font-weight:600}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.num{text-align:right;font-variant-numeric:tabular-nums}.stack{flex-direction:column;gap:20px;display:flex}.center{color:var(--text-muted);place-items:center;padding:48px 0;display:grid}.layout{grid-template-columns:var(--sidebar-w) 1fr;min-height:100%;display:grid}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;gap:8px;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;padding:8px 8px 18px;display:flex}.brand__mark{letter-spacing:.5px;color:#fff;width:40px;height:40px;box-shadow:var(--shadow-sm);background:linear-gradient(135deg,#2f6bff,#f59e0b);border-radius:11px;place-items:center;font-size:15px;font-weight:800;display:grid}.brand__text{flex-direction:column;line-height:1.2;display:flex}.brand__text strong{font-size:15px}.brand__text span{color:var(--text-muted);font-size:12px}.nav{flex-direction:column;gap:2px;display:flex}.nav__item{color:var(--text-muted);text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;padding:10px 12px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav__item:hover{background:var(--surface-2);color:var(--text)}.nav__item--active{background:var(--primary-soft);color:var(--primary);font-weight:600}.sidebar__footer{margin-top:auto}.theme-toggle{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text-muted);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:13px;transition:background .15s,color .15s;display:flex}.theme-toggle:hover{background:var(--surface-2);color:var(--text)}.content{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--surface) 70%, transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;justify-content:space-between;align-items:center;padding:22px 32px;display:flex;position:sticky;top:0}.topbar__title{font-size:21px;font-weight:700}.topbar__subtitle{color:var(--text-muted);margin-top:2px;font-size:13px}.page{width:100%;max-width:1180px;padding:28px 32px 48px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.card__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:16px;padding:18px 20px;display:flex}.card__title{font-size:15px;font-weight:650}.card__subtitle{color:var(--text-muted);margin-top:2px;font-size:12.5px}.card__body{padding:20px}.split{grid-template-columns:340px 1fr;align-items:start;gap:20px;display:grid}.split>*{min-width:0}.split__aside{position:sticky;top:96px}.form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field__label{color:var(--text-muted);font-size:12.5px;font-weight:600}.field__req{color:var(--danger)}.field__hint{color:var(--text-subtle);font-size:11.5px}.input,.select{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);width:100%;padding:10px 12px;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--text-subtle)}.input:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring);outline:none}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%237a8597' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='4 6 8 10 12 6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}.select--inline{width:auto;min-width:200px;padding:8px 32px 8px 12px}.btn{border-radius:var(--radius-sm);white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;font-weight:600;transition:background .15s,border-color .15s,transform 50ms,opacity .15s;display:inline-flex}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--md{padding:10px 16px}.btn--sm{padding:7px 12px;font-size:13px}.btn--icon{padding:8px}.btn--primary{background:var(--primary);color:var(--on-primary);box-shadow:var(--shadow-sm)}.btn--primary:not(:disabled):hover{background:var(--primary-hover)}.btn--secondary{background:var(--surface);border-color:var(--border-strong);color:var(--text)}.btn--secondary:not(:disabled):hover{background:var(--surface-2)}.btn--ghost{color:var(--primary);background:0 0}.btn--ghost:not(:disabled):hover{background:var(--primary-soft)}.btn--danger{background:var(--danger);color:#fff}.spinner{border:2.5px solid color-mix(in srgb, currentColor 25%, transparent);border-top-color:currentColor;border-radius:50%;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);align-items:center;gap:14px;padding:18px;display:flex}.stat__icon{border-radius:12px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.stat--primary .stat__icon{background:var(--primary-soft);color:var(--primary)}.stat--info .stat__icon{background:var(--info-soft);color:var(--info)}.stat--accent .stat__icon{background:var(--accent-soft);color:var(--accent-text)}.stat--success .stat__icon{background:var(--success-soft);color:var(--success)}.stat__body{flex-direction:column;min-width:0;display:flex}.stat__value{font-variant-numeric:tabular-nums;font-size:22px;font-weight:700;line-height:1.1}.stat__label{color:var(--text-muted);font-size:12.5px}.table-wrap{max-width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);border-bottom:1px solid var(--border);padding:8px 12px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--border);padding:12px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background .12s}.table tbody tr:hover{background:var(--surface-2)}.table--inner th,.table--inner td{padding:8px 12px}.badge{border-radius:999px;align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge--neutral{background:var(--surface-2);color:var(--text-muted)}.badge--success{background:var(--success-soft);color:var(--success)}.badge--accent{background:var(--accent-soft);color:var(--accent-text)}.badge--info{background:var(--info-soft);color:var(--info)}.empty{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:40px 20px;display:flex}.empty__icon{background:var(--surface-2);width:56px;height:56px;color:var(--text-subtle);border-radius:16px;place-items:center;margin-bottom:6px;display:grid}.empty__title{font-weight:600}.empty__desc{color:var(--text-muted);max-width:320px;font-size:13px}.banner{background:var(--accent-soft);color:var(--accent-text);border-radius:var(--radius);align-items:center;gap:10px;padding:12px 16px;font-size:13px;display:flex}.order-builder{grid-template-columns:1fr 320px;align-items:start;gap:20px;display:grid}.lines{margin-top:4px}.lines__head{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:4px;font-size:12.5px;font-weight:600;display:flex}.lines__empty{padding:16px 0 4px}.line{border-bottom:1px solid var(--border);grid-template-columns:1fr auto auto auto;align-items:center;gap:12px;padding:12px 0;display:grid}.line:last-child{border-bottom:none}.line__total{text-align:right;min-width:92px;font-weight:600}.line__remove{width:32px;height:32px;color:var(--text-subtle);background:0 0;border:none;border-radius:8px;place-items:center;transition:background .15s,color .15s;display:grid}.line__remove:hover{background:var(--danger-soft);color:var(--danger)}.qty{border:1px solid var(--border-strong);border-radius:var(--radius-sm);align-items:center;display:inline-flex;overflow:hidden}.qty__btn{background:var(--surface);width:30px;height:34px;color:var(--text-muted);border:none;place-items:center;transition:background .15s;display:grid}.qty__btn:hover{background:var(--surface-2);color:var(--text)}.qty__input{text-align:center;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--surface);font-variant-numeric:tabular-nums;-moz-appearance:textfield;width:46px;height:34px}.qty__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.qty__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.qty__input:focus{outline:none}.summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;gap:14px;padding:20px;display:flex;position:sticky;top:96px}.summary__title{font-size:14px;font-weight:650}.summary__lines{flex-direction:column;gap:8px;min-height:24px;display:flex}.summary__row{justify-content:space-between;align-items:center;gap:12px;font-size:13px;display:flex}.summary__name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.summary__total{border-top:1px dashed var(--border-strong);justify-content:space-between;align-items:baseline;padding-top:14px;font-weight:600;display:flex}.summary__amount{color:var(--accent-text);font-variant-numeric:tabular-nums;font-size:24px;font-weight:800}.summary__note{color:var(--text-subtle);font-size:11.5px}.summary .btn{width:100%;margin-top:2px}.orders{flex-direction:column;gap:10px;display:flex}.order{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.order__head{background:var(--surface);width:100%;color:var(--text);text-align:left;border:none;grid-template-columns:auto 1fr auto auto auto auto;align-items:center;gap:14px;padding:14px 16px;transition:background .15s;display:grid}.order__head:hover{background:var(--surface-2)}.order__head .rot{transform:rotate(180deg)}.order__head svg{color:var(--text-subtle);transition:transform .2s}.order__id{color:var(--text);font-weight:700}.order__total{color:var(--text);font-size:15px}.order__items{background:var(--surface-2);border-top:1px solid var(--border);padding:4px 16px 14px}.toasts{z-index:50;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:20px;right:20px}.toasts__region{display:contents}.toast{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);min-width:280px;max-width:380px;box-shadow:var(--shadow-lg);align-items:center;gap:10px;padding:12px 14px;animation:.22s toast-in;display:flex}.toast__msg{flex:1;font-size:13px}.toast__close{color:var(--text-subtle);background:0 0;border:none;border-radius:6px;place-items:center;padding:2px;display:grid}.toast__close:hover{color:var(--text)}.toast--success{border-left:3px solid var(--success)}.toast--success>svg{color:var(--success)}.toast--error{border-left:3px solid var(--danger)}.toast--error>svg{color:var(--danger)}.toast--info{border-left:3px solid var(--info)}.toast--info>svg{color:var(--info)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}}@media (width<=960px){.layout{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--border);flex-flow:wrap;align-items:center;height:auto;position:static}.brand{padding:4px 8px}.nav{flex-flow:wrap}.sidebar__footer{margin-top:0;margin-left:auto}.theme-toggle span{display:none}.split,.order-builder{grid-template-columns:1fr}.split__aside,.summary{position:static}.stats-grid{grid-template-columns:repeat(2,1fr)}.topbar,.page{padding-left:20px;padding-right:20px}}@media (width<=520px){.stats-grid{grid-template-columns:1fr}.order__head{grid-template-columns:auto 1fr auto;row-gap:6px}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--c-info:#2f6bff;--c-accent:#f59e0b;--c-success:#16a34a;--c-danger:#e1453a;--c-neutral:#94a3b8;--c-grid:var(--border);--c-line:#2f6bff}:root[data-theme=dark]{--c-info:#5b8cff;--c-accent:#fbbf24;--c-success:#34d27f;--c-danger:#f87171;--c-neutral:#64748b;--c-line:#5b8cff}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--c-info:#5b8cff;--c-accent:#fbbf24;--c-success:#34d27f;--c-danger:#f87171;--c-neutral:#64748b;--c-line:#5b8cff}}.stat__value-row{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.stat__delta{font-variant-numeric:tabular-nums;border-radius:999px;align-items:center;gap:3px;padding:2px 7px;font-size:12px;font-weight:600;display:inline-flex}.stat__delta--up{background:var(--success-soft);color:var(--success)}.stat__delta--down{background:var(--danger-soft);color:var(--danger)}.stat__delta--down svg{transform:scaleY(-1)}.dash-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:start;gap:20px;display:grid}.chart-area{width:100%;height:auto;display:block}.chart-axis{fill:var(--text-subtle);font-size:11px;font-family:var(--font)}.donut{flex-wrap:wrap;align-items:center;gap:24px;display:flex}.donut__chart{flex-shrink:0;width:160px}.donut__chart svg{width:100%;height:auto}.donut__value{fill:var(--text);font-size:30px;font-weight:800;font-family:var(--font);font-variant-numeric:tabular-nums}.donut__label{fill:var(--text-muted);font-size:12px;font-family:var(--font)}.donut__legend{flex-direction:column;flex:1;gap:10px;min-width:180px;list-style:none;display:flex}.donut__legend-item{align-items:center;gap:10px;font-size:13px;display:flex}.donut__dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.donut__legend-label{flex:1}.donut__legend-value{font-weight:600}.barlist{flex-direction:column;gap:16px;display:flex}.barlist__head{justify-content:space-between;gap:12px;margin-bottom:6px;font-size:13px;display:flex}.barlist__label{text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.barlist__value{flex-shrink:0;font-weight:600}.barlist__track{background:var(--surface-2);border-radius:999px;height:8px;overflow:hidden}.barlist__fill{border-radius:999px;min-width:4px;height:100%;transition:width .4s}.barlist__sub{margin-top:4px;display:block}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.search{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-subtle);align-items:center;gap:8px;padding:0 10px;display:inline-flex}.search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring);color:var(--primary)}.search__input{width:200px;max-width:48vw;color:var(--text);background:0 0;border:none;outline:none;padding:8px 0}.search__input::placeholder{color:var(--text-subtle)}.order__client{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}@media (width<=860px){.dash-row{grid-template-columns:1fr}}.modal-overlay{z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172980;place-items:center;padding:16px;animation:.16s modal-fade;display:grid;position:fixed;inset:0}@keyframes modal-fade{0%{opacity:0}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:580px;max-height:88vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow:hidden}.modal__header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 20px;display:flex}.modal__title{font-size:16px;font-weight:700}.modal__subtitle{color:var(--text-muted);margin-top:2px;font-size:12.5px}.modal__close{width:32px;height:32px;color:var(--text-subtle);background:0 0;border:none;border-radius:8px;place-items:center;display:grid}.modal__close:hover{background:var(--surface-2);color:var(--text)}.modal__body{padding:20px;overflow-y:auto}.modal__footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}@media (width<=520px){.modal-overlay{place-items:end center;padding:0}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-width:100%}}.kv{grid-template-columns:repeat(2,1fr);gap:12px 16px;display:grid}.kv__label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);font-size:11px}.kv__value{margin-top:2px;font-weight:600}.activity{flex-direction:column;display:flex}.activity__item{border-bottom:1px solid var(--border);gap:12px;padding:12px 0;display:flex}.activity__item:last-child{border-bottom:none}.activity__dot{border-radius:9px;flex-shrink:0;place-items:center;width:30px;height:30px;display:grid}.activity__dot--info{background:var(--info-soft);color:var(--info)}.activity__dot--success{background:var(--success-soft);color:var(--success)}.activity__dot--warning{background:var(--accent-soft);color:var(--accent-text)}.activity__body{flex:1;min-width:0}.activity__title{font-size:13.5px;font-weight:600}.activity__detail{color:var(--text-muted);font-size:12.5px}.activity__time{color:var(--text-subtle);white-space:nowrap;font-size:12px}.badge--danger{background:var(--danger-soft);color:var(--danger)}.seg{border:1px solid var(--border-strong);border-radius:var(--radius-sm);display:inline-flex;overflow:hidden}.seg button{background:var(--surface);color:var(--text-muted);border:none;padding:7px 14px;font-size:13px;font-weight:600}.seg button.is-active{background:var(--primary);color:var(--on-primary)}
