*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:Geist Mono,ui-monospace,SFMono-Regular,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.fixed{position:fixed}.flex{display:flex}.table{display:table}.grid{display:grid}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg: #f6f7f9;--surface: #ffffff;--surface-2: #f7f9fc;--border: #e6e9ef;--border-2: #eef0f4;--text: #0f172a;--text-2: #334155;--text-3: #64748b;--text-4: #94a3b8;--navy: #1e3a8a;--navy-700: #1e40af;--navy-600: #2547a6;--navy-50: #eef2ff;--navy-100: #e0e7ff;--gold: #c69214;--gold-600: #b8851a;--gold-50: #fdf7e3;--gold-100: #fbecc1;--green: #16a34a;--green-50: #dcfce7;--orange: #ea580c;--orange-50: #fff1e6;--red: #dc2626;--red-50: #fee2e2;--blue: #2563eb;--blue-50: #dbeafe;--slate-50: #f1f5f9;--shadow-1: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.05);--shadow-2: 0 8px 28px rgba(15,23,42,.08), 0 2px 6px rgba(15,23,42,.05)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}button{font-family:inherit}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.app-main{display:flex;flex-direction:column;min-width:0}.side{background:var(--surface);border-right:1px solid var(--border);padding:22px 14px 14px;display:flex;flex-direction:column}.side-brand{display:flex;align-items:center;gap:11px;padding:0 8px 22px}.side-brand-mark{width:34px;height:34px;border-radius:9px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #1e3a8a40;flex-shrink:0}.side-brand-mark svg{width:22px;height:22px}.side-brand-name{font-weight:700;font-size:15.5px;color:var(--text);letter-spacing:-.01em;line-height:1.15}.side-brand-sub{font-size:11px;color:var(--text-4);font-weight:500}.side-section{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text-4);margin:14px 12px 6px}.side-nav{display:flex;flex-direction:column;gap:2px}.side-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:var(--text-2);font-weight:500;font-size:13.5px;cursor:pointer;border:none;background:transparent;text-align:left;width:100%;transition:background .15s,color .15s}.side-item:hover{background:var(--surface-2);color:var(--text)}.side-item.active{background:var(--navy);color:#fff;font-weight:600;box-shadow:0 2px 6px #1e3a8a40}.side-item .ico{width:17px;height:17px;flex:0 0 17px}.side-count{margin-left:auto;background:var(--slate-50);color:var(--text-3);font-size:11px;font-weight:600;padding:1px 7px;border-radius:999px;font-family:Geist Mono,monospace}.side-item.active .side-count{background:#ffffff2e;color:#fff}.side-spacer{flex:1;min-height:12px}.side-user{display:flex;align-items:center;gap:11px;padding:10px 8px;border-top:1px solid var(--border-2);margin-top:6px}.side-avatar{width:36px;height:36px;border-radius:50%;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex:0 0 36px;letter-spacing:.02em}.side-user-meta{line-height:1.25;flex:1;min-width:0}.side-user-name{font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-user-role{font-size:11.5px;color:var(--text-4)}.side-user-btn{background:transparent;border:none;color:var(--text-3);cursor:pointer;padding:4px;border-radius:6px;display:flex;align-items:center;justify-content:center}.side-user-btn:hover{background:var(--surface-2);color:var(--text)}.topbar{height:64px;border-bottom:1px solid var(--border);background:var(--surface);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:10}.topbar-title{font-size:18px;font-weight:700;letter-spacing:-.015em;color:var(--text);margin:0;white-space:nowrap}.topbar-crumb{color:var(--text-4);font-size:12.5px;font-weight:500;margin-left:2px}.topbar-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-3);width:280px;font-size:13px}.topbar-search input{border:none;outline:none;background:transparent;flex:1;font:inherit;color:var(--text);min-width:0}.topbar-search input::-moz-placeholder{color:var(--text-4)}.topbar-search input::placeholder{color:var(--text-4)}.topbar-icon-btn{width:36px;height:36px;border-radius:9px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative}.topbar-icon-btn:hover{background:var(--surface-2)}.topbar-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid var(--surface)}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;background:var(--navy);color:#fff;border:none;border-radius:9px;font-weight:600;font-size:13.5px;cursor:pointer;white-space:nowrap;box-shadow:0 2px 6px #1e3a8a40;transition:background .15s,transform .05s}.btn-primary:hover{background:var(--navy-700)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;background:var(--surface);color:var(--text-2);border:1px solid var(--border);border-radius:9px;font-weight:600;font-size:13px;cursor:pointer}.btn-secondary:hover{background:var(--surface-2);color:var(--text)}.page{padding:24px 28px 40px;flex:1}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:16px}.page-title{font-size:24px;font-weight:700;letter-spacing:-.018em;margin:0 0 4px}.page-sub{font-size:13px;color:var(--text-3);margin:0}.page-head-actions{display:flex;gap:10px}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-1)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px}.card-title{font-size:15px;font-weight:700;letter-spacing:-.01em;margin:0}.card-link{font-size:12.5px;color:var(--navy);font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:4px}.card-link:hover{text-decoration:underline}.stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-bottom:16px}@media(max-width:1280px){.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.stat{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px 16px;box-shadow:var(--shadow-1)}.stat-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.stat-icon{width:28px;height:28px;border-radius:7px;background:var(--navy-50);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.gold{background:var(--gold-50);color:var(--gold)}.stat-icon.green{background:var(--green-50);color:var(--green)}.stat-icon.orange{background:var(--orange-50);color:var(--orange)}.stat-icon.blue{background:var(--blue-50);color:var(--blue)}.stat-label-text{font-size:12.5px;color:var(--text-3);font-weight:500;flex:1;min-width:0}.stat-delta{display:inline-flex;align-items:center;gap:3px;font-size:11.5px;font-weight:600}.stat-delta.up{color:var(--green)}.stat-delta.down{color:var(--red)}.stat-value-row{display:flex;align-items:baseline;gap:8px;white-space:nowrap;flex-wrap:nowrap}.stat-value{font-family:Geist Mono,ui-monospace,monospace;font-size:22px;font-weight:600;letter-spacing:-.02em;color:var(--text);font-feature-settings:"tnum" 1}.stat-unit{font-size:11px;color:var(--text-4);font-weight:600}.stat-foot{font-size:11.5px;color:var(--text-4);margin-top:6px;font-weight:500}.stat-foot strong{color:var(--text-2);font-weight:600}.row-2{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}@media(max-width:1180px){.row-2{grid-template-columns:1fr}}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;padding:6px 20px 18px}.action-tile{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--surface);cursor:pointer;text-align:left;transition:border-color .15s,background .15s;width:100%}.action-tile:hover{border-color:var(--navy);background:var(--navy-50)}.action-icon{width:34px;height:34px;border-radius:8px;background:var(--slate-50);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}.action-title{font-weight:600;font-size:13px;color:var(--text)}.action-sub{font-size:11.5px;color:var(--text-4);margin-top:1px}.chart-wrap{position:relative;height:240px;padding:0 20px 16px}.legend{display:flex;gap:16px;align-items:center}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);font-weight:500}.legend-dot{width:8px;height:8px;border-radius:50%}.bar-tooltip{position:absolute;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:8px 12px;box-shadow:var(--shadow-2);pointer-events:none;z-index:2;min-width:150px}.bar-tooltip-row1{display:inline-flex;align-items:center;gap:6px;color:var(--text-3);font-size:11.5px;font-weight:500}.bar-tooltip-value{font-family:Geist Mono,monospace;font-size:16px;font-weight:600;font-feature-settings:"tnum" 1;color:var(--text);margin-top:2px}.ship-list{padding:0 20px 16px}.ship-row{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--border-2)}.ship-row:last-child{border-bottom:none}.ship-date{width:44px;padding:4px 0;border-radius:8px;background:var(--navy-50);color:var(--navy);text-align:center;line-height:1}.ship-date-m{font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);opacity:.7;display:block}.ship-date-d{font-family:Geist Mono,monospace;font-weight:700;font-size:16px;display:block;margin-top:2px}.ship-title{font-weight:600;font-size:13.5px;color:var(--text)}.ship-meta{font-size:11.5px;color:var(--text-4);margin-top:1px;display:inline-flex;gap:6px;align-items:center}.ship-code{font-family:Geist Mono,monospace;font-weight:600;color:var(--text-2);font-size:13px;text-align:right}.ship-code-sub{font-size:11px;color:var(--text-4);font-weight:500;margin-top:1px}.tbl-wrap{padding:0 0 8px;overflow-x:auto}table.tbl{width:100%;min-width:760px;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-weight:600;color:var(--text-4);font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:8px 12px;border-bottom:1px solid var(--border-2);background:var(--surface-2);white-space:nowrap}.tbl tbody td{padding:12px;border-bottom:1px solid var(--border-2);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--surface-2);cursor:pointer}.tbl .num{font-family:Geist Mono,monospace;font-feature-settings:"tnum" 1;text-align:right;white-space:nowrap}.inv-no{font-family:Geist Mono,monospace;font-weight:600;color:var(--text)}.cust{display:flex;align-items:center;gap:10px}.cust-avatar{width:28px;height:28px;border-radius:50%;background:var(--slate-50);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px;flex:0 0 28px}.cust-name{font-weight:600;color:var(--text);line-height:1.25}.cust-recip{font-size:11.5px;color:var(--text-4)}.act-btn{background:transparent;border:none;width:26px;height:26px;border-radius:6px;color:var(--text-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.act-btn:hover{background:var(--slate-50);color:var(--text)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:50%}.badge.paid{background:var(--green-50);color:#15803d}.badge.paid .badge-dot{background:var(--green)}.badge.partial{background:var(--orange-50);color:#c2410c}.badge.partial .badge-dot{background:var(--orange)}.badge.unpaid{background:var(--red-50);color:#b91c1c}.badge.unpaid .badge-dot{background:var(--red)}.badge.draft{background:var(--blue-50);color:#1d4ed8}.badge.draft .badge-dot{background:var(--blue)}.badge.cancelled{background:var(--slate-50);color:var(--text-3)}.badge.cancelled .badge-dot{background:var(--text-4)}.route-chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-2);font-weight:500;background:var(--slate-50);padding:3px 8px;border-radius:6px;white-space:nowrap}.btn-primary.lg{padding:12px 16px;font-size:14px;width:100%;justify-content:center}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:7px 10px;background:transparent;color:var(--text-3);border:none;border-radius:8px;font-weight:600;font-size:12.5px;cursor:pointer}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.page-back{display:inline-flex;align-items:center;gap:6px;color:var(--text-3);font-size:12.5px;font-weight:600;background:transparent;border:none;cursor:pointer;padding:0;margin-bottom:6px}.page-back:hover{color:var(--navy)}.page-sub .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-right:5px;vertical-align:middle}.invoice-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:20px;align-items:start}@media(max-width:1180px){.invoice-layout{grid-template-columns:minmax(0,1fr)}.summary-col{position:static!important}}.form-col{display:flex;flex-direction:column;gap:16px;min-width:0}.summary-col{position:sticky;top:80px}.sec{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-1);overflow:hidden}.sec-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-2)}.sec-num{width:26px;height:26px;border-radius:50%;background:var(--navy-50);color:var(--navy);font-family:Geist Mono,monospace;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sec-num.done{background:var(--green-50);color:var(--green)}.sec-head-meta{line-height:1.2;flex:1;min-width:0}.sec-title{font-size:14.5px;font-weight:700;letter-spacing:-.005em;margin:0}.sec-sub{font-size:12px;color:var(--text-4);margin-top:1px}.sec-body{padding:18px 20px 20px}.fgrid{display:grid;gap:14px}.fgrid-2{grid-template-columns:1fr 1fr}.fgrid-3{grid-template-columns:1fr 1fr 1fr}.fgrid-4{grid-template-columns:1fr 1fr 1fr 1fr}.fspan-2{grid-column:span 2}.fspan-3{grid-column:span 3}.fspan-all{grid-column:1 / -1}@media(max-width:720px){.fgrid-2,.fgrid-3,.fgrid-4{grid-template-columns:1fr}.fspan-2,.fspan-3{grid-column:auto}}.field{display:flex;flex-direction:column;gap:5px;min-width:0}.field-label{font-size:12px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:4px}.field-label .req{color:var(--red);font-weight:700}.field-label .opt{color:var(--text-4);font-size:10.5px;font-weight:500;margin-left:4px;text-transform:uppercase;letter-spacing:.04em}.field-hint{font-size:11.5px;color:var(--text-4)}.field-error{font-size:11.5px;color:var(--red);font-weight:500}.fi-input,.fi-select,.fi-textarea{width:100%;min-width:0;padding:9px 12px;border:1px solid var(--border);background:var(--surface);border-radius:9px;font:inherit;font-size:13.5px;color:var(--text);outline:none;transition:border-color .12s,box-shadow .12s}.fi-input::-moz-placeholder,.fi-textarea::-moz-placeholder{color:var(--text-4)}.fi-input::placeholder,.fi-textarea::placeholder{color:var(--text-4)}.fi-input:focus,.fi-select:focus,.fi-textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1e3a8a26}.fi-input:disabled,.fi-select:disabled{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}.fi-input.has-suffix{padding-right:56px}.fi-input.has-prefix{padding-left:44px}.fi-input.has-err{border-color:var(--red)}.fi-input.has-err:focus{box-shadow:0 0 0 3px #dc262626}.fi-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}.fi-textarea{resize:vertical;min-height:78px;font-family:inherit}.input-wrap{position:relative}.input-prefix{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px;pointer-events:none;font-family:Geist Mono,monospace;font-weight:500}.input-suffix{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-4);font-size:11px;font-weight:600;pointer-events:none;letter-spacing:.02em}.phone{display:grid;grid-template-columns:100px 1fr;gap:8px}.seg{display:inline-flex;border:1px solid var(--border);background:var(--surface-2);border-radius:9px;padding:3px;gap:2px}.seg.full{display:flex}.seg-btn{flex:1;padding:7px 12px;border:none;background:transparent;border-radius:7px;font:inherit;font-size:12.5px;font-weight:600;color:var(--text-3);cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:5px}.seg-btn:hover{color:var(--text)}.seg-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-1)}.toggle{display:inline-flex;align-items:center;gap:9px;cursor:pointer;padding:4px 0}.toggle input{display:none}.toggle-track{width:32px;height:18px;background:#cbd5e1;border-radius:999px;position:relative;transition:background .15s;flex-shrink:0}.toggle-track:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 2px #0003;transition:left .18s}.toggle input:checked+.toggle-track{background:var(--navy)}.toggle input:checked+.toggle-track:after{left:16px}.toggle-label{font-size:13px;font-weight:600;color:var(--text-2)}.toggle-sub{font-size:11.5px;color:var(--text-4);font-weight:500}.more-link{display:inline-flex;align-items:center;gap:4px;color:var(--navy);font-weight:600;font-size:12.5px;background:transparent;border:none;cursor:pointer;padding:6px 0 0}.more-link:hover{text-decoration:underline}.pkg-list{display:flex;flex-direction:column;gap:12px;padding:0 20px 4px}.pkg{border:1px solid var(--border);border-radius:12px;background:var(--surface);transition:border-color .15s,box-shadow .15s}.pkg.open{border-color:var(--navy-100);box-shadow:0 0 0 3px #1e3a8a0d}.pkg-head{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:12px;align-items:center;padding:12px 14px;cursor:pointer}.pkg-badge{background:var(--navy-50);color:var(--navy);border-radius:7px;padding:4px 9px;font-size:11.5px;font-weight:700;font-family:Geist Mono,monospace;letter-spacing:.02em}.pkg-summary{min-width:0}.pkg-desc{font-weight:600;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pkg-meta{font-size:11.5px;color:var(--text-4);margin-top:1px}.pkg-meta .cat{display:inline-block;padding:1px 7px;background:var(--slate-50);border-radius:5px;color:var(--text-2);font-weight:600;margin-right:6px;font-size:11px}.pkg-weight{font-family:Geist Mono,monospace;font-size:12.5px;color:var(--text-3);font-weight:600;white-space:nowrap}.pkg-price{font-family:Geist Mono,monospace;font-size:14px;color:var(--text);font-weight:700;white-space:nowrap}.pkg-actions{display:flex;gap:2px}.pkg-act-btn{width:28px;height:28px;border-radius:6px;background:transparent;border:none;color:var(--text-3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.pkg-act-btn:hover{background:var(--slate-50);color:var(--text)}.pkg-act-btn.danger:hover{background:var(--red-50);color:var(--red)}.pkg-body{padding:6px 16px 16px;border-top:1px solid var(--border-2)}.pkg-body-inner{padding-top:14px}.pkg-add{display:flex;align-items:center;justify-content:center;gap:7px;padding:12px;border:1.5px dashed #cbd5e1;border-radius:12px;background:transparent;color:var(--text-3);font-weight:600;font-size:13px;cursor:pointer;transition:border-color .15s,background .15s,color .15s;font-family:inherit}.pkg-add:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-50)}.pkg-mode-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;background:var(--surface-2);border:1px solid var(--border-2);border-radius:5px;font-size:10.5px;font-weight:600;color:var(--text-3);margin-left:5px}.pkg-mode-chip.manual{background:var(--gold-50);border-color:var(--gold-100);color:var(--gold-600)}.calc-chip{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;padding:8px 12px;background:var(--gold-50);border:1px solid var(--gold-100);border-radius:9px;font-size:12.5px;color:var(--text-2)}.calc-chip strong{font-family:Geist Mono,monospace;color:var(--gold-600);font-weight:700}.summary{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-1);overflow:hidden}.summary-head{padding:16px 20px;background:linear-gradient(180deg,#1e3a8a,#1f3da0);color:#fff}.summary-head-row{display:flex;align-items:center;justify-content:space-between}.summary-head h3{margin:0;font-size:13.5px;font-weight:700;letter-spacing:-.005em}.summary-curr-chip{background:#ffffff2e;color:#fff;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.02em;font-family:Geist Mono,monospace}.summary-head-stats{display:flex;gap:16px;margin-top:10px}.summary-head-stat{display:flex;flex-direction:column;gap:1px}.summary-head-stat-l{font-size:10.5px;opacity:.75;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.summary-head-stat-v{font-family:Geist Mono,monospace;font-size:18px;font-weight:700;letter-spacing:-.02em}.summary-body{padding:16px 20px}.sum-row{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;font-size:13px}.sum-row .l{color:var(--text-3);font-weight:500}.sum-row .v{font-family:Geist Mono,monospace;color:var(--text);font-weight:600;font-feature-settings:"tnum" 1}.sum-row.discount .v{color:var(--green)}.sum-divider{height:1px;background:var(--border-2);margin:8px 0}.sum-total{display:flex;justify-content:space-between;align-items:baseline;padding:10px 0 2px}.sum-total .l{font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.sum-total .v{font-family:Geist Mono,monospace;font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.sum-paid{display:flex;justify-content:space-between;padding:8px 0;font-size:13px}.sum-paid .l{color:var(--text-3);font-weight:500}.sum-paid .v{font-family:Geist Mono,monospace;color:var(--green);font-weight:700}.sum-balance{display:flex;justify-content:space-between;align-items:baseline;padding:10px 12px;margin:4px -4px 0;border-radius:10px;background:var(--orange-50)}.sum-balance.zero{background:var(--green-50)}.sum-balance.full{background:var(--red-50)}.sum-balance .l{font-size:12px;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.sum-balance .v{font-family:Geist Mono,monospace;font-size:18px;font-weight:700;color:var(--orange)}.sum-balance.zero .v{color:var(--green)}.sum-balance.full .v{color:var(--red)}.sum-status{display:flex;align-items:center;justify-content:center;gap:6px;padding:9px;border-radius:9px;font-size:12.5px;font-weight:700;margin-top:12px;letter-spacing:.02em}.sum-status .dot{width:8px;height:8px;border-radius:50%}.sum-status.paid{background:var(--green-50);color:#15803d}.sum-status.paid .dot{background:var(--green)}.sum-status.partial{background:var(--orange-50);color:#c2410c}.sum-status.partial .dot{background:var(--orange)}.sum-status.unpaid{background:var(--red-50);color:#b91c1c}.sum-status.unpaid .dot{background:var(--red)}.summary-actions{padding:14px 20px 20px;border-top:1px solid var(--border-2);display:flex;flex-direction:column;gap:8px}.summary-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.summary-foot{padding:0 20px 16px;font-size:11px;color:var(--text-4);display:flex;align-items:center;gap:6px}.inv-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg);overflow-y:auto}.inv-overlay-bar{position:sticky;top:0;z-index:10;background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:var(--shadow-1)}.inv-overlay-bar-center{font-size:14px;font-weight:600;color:var(--text)}.inv-overlay-bar-sub{font-size:12px;color:var(--text-4);font-weight:400;margin-left:8px}.inv-doc-wrap{max-width:840px;margin:0 auto;padding:32px 20px 60px}.inv-doc{background:var(--surface);border-radius:12px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-2)}.inv-doc-head{background:linear-gradient(135deg,#0f1e4a 0%,var(--navy) 100%);padding:28px 32px;display:flex;justify-content:space-between;align-items:flex-start;gap:24px}.inv-doc-brand-name{font-size:18px;font-weight:700;color:var(--gold);letter-spacing:.1em;font-family:Geist Mono,monospace}.inv-doc-brand-sub{font-size:11px;color:#ffffff73;margin-top:4px;letter-spacing:.04em}.inv-doc-meta{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.inv-doc-draft{font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--gold);background:#c692142e;border:1px solid rgba(198,146,20,.35);padding:3px 10px;border-radius:4px}.inv-doc-dates{display:flex;gap:24px}.inv-doc-dates>div{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.inv-doc-dates span{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.08em}.inv-doc-dates strong{font-size:12px;color:#ffffffe0;font-family:Geist Mono,monospace;font-weight:500}.inv-parties{display:grid;grid-template-columns:1fr 52px 1fr;padding:26px 32px;border-bottom:1px solid var(--border-2);align-items:start}.inv-party-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-4);margin-bottom:8px}.inv-party-name{font-size:16px;font-weight:700;color:var(--text);margin-bottom:6px}.inv-party-detail{font-size:13px;color:var(--text-3);line-height:1.6}.inv-party-tag{font-size:11px;color:var(--text-4);margin-right:4px}.inv-party-arrow{display:flex;align-items:center;justify-content:center;padding-top:28px;font-size:20px;color:var(--gold)}.inv-section{padding:22px 32px;border-bottom:1px solid var(--border-2)}.inv-section:last-child{border-bottom:none}.inv-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-4);margin-bottom:14px}.inv-pkg-table{width:100%;border-collapse:collapse;font-size:13px}.inv-pkg-table th{text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-4);padding:0 14px 10px 0;border-bottom:1px solid var(--border)}.inv-pkg-table th:last-child,.inv-pkg-table td:last-child{padding-right:0;text-align:right}.inv-pkg-table td{padding:11px 14px 11px 0;color:var(--text-2);border-bottom:1px solid var(--border-2);vertical-align:top}.inv-pkg-table tbody tr:last-child td{border-bottom:none}.inv-pkg-num{font-family:Geist Mono,monospace;font-size:11px;color:var(--text-4)!important;width:28px}.inv-pkg-price{font-family:Geist Mono,monospace;font-weight:600;color:var(--text)!important}.inv-pkg-notes{font-size:11px;color:var(--text-4);margin-top:3px;font-style:italic}.inv-pkg-badge{display:inline-block;font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;margin-left:5px;background:var(--orange-50);color:var(--orange)}.inv-financials{padding:24px 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;border-bottom:1px solid var(--border-2)}.inv-fin-rows{display:flex;flex-direction:column;gap:9px;min-width:320px}.inv-fin-row{display:flex;justify-content:space-between;align-items:center;gap:40px;font-size:13px;color:var(--text-3)}.inv-fin-row>span:last-child{font-family:Geist Mono,monospace;font-weight:500;white-space:nowrap}.inv-fin-row.discount{color:var(--green)}.inv-fin-row.discount>span:last-child{color:var(--green)}.inv-fin-divider{height:1px;background:var(--border);margin:4px 0}.inv-fin-row.total{font-size:16px;font-weight:700;color:var(--text)}.inv-fin-row.total>span:last-child{font-size:16px;font-weight:700}.inv-fin-row.paid>span:last-child{color:var(--green);font-weight:600}.inv-fin-row.balance.paid>span:last-child{color:var(--text-4)}.inv-fin-row.balance.partial>span:last-child{color:var(--orange);font-weight:600}.inv-fin-row.balance.unpaid>span:last-child{color:var(--red);font-weight:600}.inv-status-pill{padding:8px 16px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.02em;white-space:nowrap}.inv-status-pill.paid{background:var(--green-50);color:#15803d}.inv-status-pill.partial{background:var(--orange-50);color:#c2410c}.inv-status-pill.unpaid{background:var(--red-50);color:#b91c1c}.inv-note{font-size:13px;color:var(--text-2);line-height:1.65;padding:13px 16px;background:var(--gold-50);border-radius:8px;border-left:3px solid var(--gold)}.inv-internal{padding:14px 32px;background:var(--surface-2);display:flex;gap:24px;flex-wrap:wrap}.inv-internal-item{font-size:11px;color:var(--text-4);display:flex;gap:6px}.inv-internal-item strong{color:var(--text-3);font-weight:500}.inv-preview-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.validation-banner{background:var(--red-50);color:#b91c1c;border:1px solid #fca5a5;border-radius:10px;padding:10px 14px;font-size:13px;font-weight:500;margin-bottom:8px}.pkg-badge.has-err{background:var(--red-50);color:#b91c1c}.btn-primary:disabled{background:var(--text-4);cursor:not-allowed;box-shadow:none;transform:none}.ship-date-warning{font-size:12.5px;font-weight:500;color:#92400e;background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:8px 12px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:40px 16px}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-2);padding:36px}.login-brand{margin-bottom:22px}.login-brand-name{font-size:18px;font-weight:700;letter-spacing:-.015em;color:var(--text)}.login-brand-sub{font-size:11.5px;color:var(--text-4);font-weight:500;margin-top:2px}.login-form{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:12.5px;font-weight:600;color:var(--text-2)}.login-pwd-wrap{position:relative}.login-input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:14px;font-family:inherit;outline:none;transition:border-color .12s,box-shadow .12s}.login-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px #1e3a8a26}.login-input::-moz-placeholder{color:var(--text-4)}.login-input::placeholder{color:var(--text-4)}.login-input:disabled{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}.login-input-pwd{padding-right:42px}.login-input-error{border-color:var(--red)}.login-input-error:focus{box-shadow:0 0 0 3px #dc262626}.login-pwd-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:7px;border:none;background:transparent;color:var(--text-3);display:flex;align-items:center;justify-content:center;cursor:pointer}.login-pwd-toggle:hover{background:var(--surface-2);color:var(--text)}.login-error{font-size:12.5px;color:#991b1b;background:var(--red-50);border:1px solid #fecaca;border-radius:8px;padding:10px 13px;line-height:1.45}.login-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;background:var(--navy);color:#fff;border:none;border-radius:10px;font-weight:700;font-size:14px;font-family:inherit;cursor:pointer;box-shadow:0 2px 6px #1e3a8a40;transition:background .15s,transform .05s;margin-top:4px}.login-submit:hover:not(:disabled){background:var(--navy-700)}.login-submit:active:not(:disabled){transform:translateY(1px)}.login-submit:disabled{background:var(--text-4);cursor:not-allowed;box-shadow:none}.login-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.inv-created-page{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 28px 60px}.inv-created-card{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-2);padding:44px 36px 36px;text-align:center}.inv-created-icon{color:var(--green);margin-bottom:16px}.inv-created-heading{font-size:24px;font-weight:800;letter-spacing:-.022em;margin-bottom:6px}.inv-created-sub{font-size:14px;color:var(--text-3);margin-bottom:24px}.inv-created-number-wrap{padding:20px 22px;background:var(--surface-2);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;text-align:left}.inv-created-number-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);margin-bottom:6px}.inv-created-number{font-family:Geist Mono,Courier New,monospace;font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:8px;word-break:break-all}.inv-created-status{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600}.status-paid{background:var(--green-50);color:#15803d}.status-partial{background:var(--gold-50);color:var(--gold-600)}.status-unpaid{background:var(--red-50);color:var(--red)}.inv-created-totals{text-align:left;padding:16px 0;border-top:1px solid var(--border-2);border-bottom:1px solid var(--border-2);margin-bottom:24px;display:flex;flex-direction:column;gap:10px}.inv-created-row{display:flex;justify-content:space-between;font-size:13.5px;color:var(--text-2)}.inv-created-row-total{font-size:15px;font-weight:700;color:var(--text)}.inv-created-row-balance{color:var(--red);font-weight:600}.inv-created-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
