@import "https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&family=Geist+Mono:wght@400;500;600&family=Noto+Sans+Thai:wght@400;500;600;700&display=swap";:root{--bg:#fafafa;--fg:#18181b;--card:#fff;--muted:#f4f4f5;--muted-fg:#71717a;--faint:#a1a1aa;--border:#e8e8eb;--hair:#f0f0f2;--primary:#18181b;--primary-hover:#27272a;--primary-fg:#fafafa;--red:#dc2626;--red-bg:#fef2f2;--amber:#b45309;--amber-bg:#fff8eb;--green:#15803d;--green-bg:#f0fdf4;--sans:"Geist", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--r-lg:12px;--r-md:9px;--r-sm:6px;--shadow:0 1px 2px #18181b0d, 0 1px 1px #18181b08;--shadow-h:0 4px 14px #18181b12, 0 1px 3px #18181b0d}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--fg);font-size:14px;line-height:1.5;font-family:var(--sans);-webkit-font-smoothing:antialiased;letter-spacing:-.005em;margin:0}a{color:inherit;text-decoration:none}svg{fill:none;stroke:currentColor;stroke-width:1.75px;stroke-linecap:round;stroke-linejoin:round}.num{font-family:var(--mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1;letter-spacing:-.02em}.eyebrow{color:var(--faint);text-transform:uppercase;letter-spacing:.09em;font-size:10.5px;font-weight:600}.muted{color:var(--muted-fg)}.faint{color:var(--faint)}.right{text-align:right}.app{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--border);background:#fff;flex-direction:column;gap:4px;height:100vh;padding:16px 12px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:9px;padding:6px 10px 16px;font-size:15px;font-weight:600;display:flex}.brand .dotmark{background:var(--primary);border-radius:50%;width:9px;height:9px}.brand small{font-family:var(--mono);color:var(--faint);font-size:11px;font-weight:500}.nav{border-radius:var(--r-md);color:var(--muted-fg);cursor:pointer;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;font-weight:500;display:flex}.nav svg{width:17px;height:17px}.nav:hover,.nav.active{background:var(--muted);color:var(--fg)}.nav-badge{min-width:17px;height:17px;font-family:var(--mono);font-variant-numeric:tabular-nums;background:var(--border);color:var(--muted-fg);border-radius:9px;justify-content:center;align-items:center;margin-left:auto;padding:0 5px;font-size:10.5px;font-weight:600;line-height:1;display:inline-flex}.nav.active .nav-badge{background:var(--primary);color:var(--primary-fg)}.sidebar .spacer{flex:1}.userbox{border-top:1px solid var(--hair);color:var(--muted-fg);padding-top:12px;font-size:12px}.userbox b{color:var(--fg);font-size:13px;font-weight:600;display:block}.main{min-width:0}.content{max-width:1060px;margin:0 auto;padding:30px 26px 72px}.fab{right:16px;bottom:calc(72px + env(safe-area-inset-bottom));background:var(--primary);width:52px;height:52px;color:var(--primary-fg);cursor:pointer;box-shadow:var(--shadow-h);z-index:31;border:0;border-radius:50%;place-items:center;display:none;position:fixed}.fab:active{transform:translateY(.5px)}.fab svg{width:22px;height:22px}.nav-burger{font:inherit;cursor:pointer;background:0 0;border:0;display:none}.drawer,.drawer-backdrop{display:none}@media (width<=760px){.app{grid-template-columns:1fr}.sidebar{border-right:0;border-top:1px solid var(--border);height:auto;padding:6px 4px calc(6px + env(safe-area-inset-bottom));z-index:30;flex-direction:row;justify-content:space-around;gap:0;position:fixed;inset:auto 0 0;box-shadow:0 -1px 4px #18181b0d}.brand,.userbox,.sidebar .spacer,.sidebar .btn-log,.nav-sec{display:none}.nav{text-align:center;flex-direction:column;flex:1;gap:3px;min-width:0;padding:6px 2px;font-size:9.5px;position:relative}.nav svg{width:19px;height:19px}.nav .nav-badge{background:var(--primary);min-width:15px;height:15px;color:var(--primary-fg);margin-left:7px;padding:0 4px;font-size:9.5px;position:absolute;top:2px;left:50%}.drawer .nav .nav-badge{background:var(--border);color:var(--muted-fg);margin-left:auto;position:static}.nav-burger{min-width:0;color:var(--muted-fg);flex-direction:column;flex:1;align-items:center;gap:3px;padding:6px 2px;font-size:9.5px;display:flex}.nav-burger svg{width:19px;height:19px}.content{padding:18px 14px 96px}.fab{display:grid}.drawer-backdrop{opacity:0;pointer-events:none;z-index:40;background:#18181b66;transition:opacity .2s;display:block;position:fixed;inset:0}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{border-left:1px solid var(--border);width:252px;max-width:82vw;padding:18px 14px calc(18px + env(safe-area-inset-bottom));z-index:41;background:#fff;flex-direction:column;gap:4px;transition:transform .22s;display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%);box-shadow:-2px 0 16px #18181b1f}.drawer.open{transform:translate(0)}.drawer .nav{text-align:left;flex-direction:row;flex:none;gap:10px;padding:9px 10px;font-size:13.5px}.drawer .nav svg{width:17px;height:17px}.drawer .spacer{flex:1}.drawer-head{border-bottom:1px solid var(--hair);margin-bottom:8px;padding:4px 4px 12px}.drawer-head b{font-size:14px;display:block}.drawer-head .faint{font-size:12px}}.btn{font:inherit;border-radius:var(--r-md);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:7px;height:36px;padding:0 14px;font-size:13px;font-weight:500;transition:background .15s,box-shadow .15s,transform 50ms;display:inline-flex}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:default}.btn svg{width:15px;height:15px}.btn.primary{background:var(--primary);color:var(--primary-fg)}.btn.primary:hover{background:var(--primary-hover)}.btn.outline{color:var(--fg);border-color:var(--border);box-shadow:var(--shadow);background:#fff}.btn.outline:hover{background:var(--muted)}.btn.ghost{color:var(--muted-fg);background:0 0}.btn.ghost:hover{background:var(--muted);color:var(--fg)}.btn.danger{background:var(--red);color:#fff;border-color:var(--red)}.btn.danger:hover{filter:brightness(.94)}.void-note{background:var(--red-bg);border-radius:var(--r-md);color:#7f1d1d;border:1px solid #f3d0d0;margin-bottom:12px;padding:10px 12px;font-size:12.5px;line-height:1.5}.struck{opacity:.6}.struck .tl-title,.struck .nm,.struck .feed-kind,.struck .det{text-decoration:line-through}.void-tag{letter-spacing:.05em;color:var(--red);vertical-align:middle;border:1px solid #f3d0d0;border-radius:4px;margin-left:6px;padding:0 4px;font-size:9.5px;font-weight:700}.detail-grid{flex-direction:column;gap:2px;display:flex}.detail-row{border-bottom:1px solid var(--hair);gap:12px;padding:8px 0;font-size:13px;display:flex}.detail-row:last-child{border-bottom:0}.detail-k{width:110px;color:var(--muted-fg);flex:none;font-size:12px}.detail-v{flex:1;min-width:0}.tl-item.click{cursor:pointer;border-radius:var(--r-md)}.tl-item.click:hover{background:var(--muted)}.row-kebab{flex:none;position:relative}.row-kebab>button{color:var(--muted-fg);cursor:pointer;opacity:0;background:0 0;border:0;border-radius:6px;padding:4px}.tl-item:hover .row-kebab>button,.row-kebab.open>button{opacity:1}.row-kebab>button:hover{background:var(--muted);color:var(--fg)}.row-kebab-pop{z-index:30;border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg,0 8px 24px #0000001f);background:#fff;min-width:150px;padding:4px;position:absolute;top:100%;right:0}.row-kebab-pop button,.row-kebab-pop a{width:100%;font:inherit;color:var(--fg);cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;align-items:center;gap:8px;padding:7px 9px;font-size:12.5px;text-decoration:none;display:flex}.row-kebab-pop button:hover,.row-kebab-pop a:hover{background:var(--muted)}.row-kebab-pop .danger{color:var(--red)}.row-kebab-pop svg{width:14px;height:14px}.btn.sm{height:30px;padding:0 10px;font-size:12px}.input{font:inherit;border:1px solid var(--border);border-radius:var(--r-md);height:36px;color:var(--fg);background:#fff;width:100%;padding:0 11px;font-size:13px}.input:focus{outline:2px solid var(--fg);outline-offset:-1px}label.field,.field{margin-bottom:12px;display:block}label.field>span,.field>.field-label{color:var(--muted-fg);margin-bottom:5px;font-size:12px;font-weight:500;display:block}.field-label{justify-content:space-between;align-items:baseline;display:flex}.badge{border-radius:999px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:500;line-height:1.4;display:inline-flex}.badge.secondary{background:var(--muted);color:#52525b}.badge.outline{color:#52525b;border:1px solid var(--border);background:0 0}.badge.red{background:var(--red-bg);color:var(--red)}.badge.amber{background:var(--amber-bg);color:var(--amber)}.badge.green{background:var(--green-bg);color:var(--green)}.pagehead{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:22px;display:flex}.pagehead h1{letter-spacing:-.03em;margin:0;font-size:24px;font-weight:600}.pagehead .sub{color:var(--muted-fg);margin-top:4px;font-size:13px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);margin-bottom:11px;padding:16px 17px;transition:box-shadow .18s,transform .18s;position:relative}.card.hoverable{cursor:pointer}.card.hoverable:hover{box-shadow:var(--shadow-h);transform:translateY(-1px)}.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);margin-bottom:14px;padding:16px}.panel h3{margin:0 0 13px}.dot{border-radius:50%;flex:none;width:7px;height:7px;display:inline-block}.dot.green{background:var(--green)}.dot.amber{background:#d97706}.dot.red{background:var(--red)}.grid3{grid-template-columns:258px minmax(0,1fr) 238px;grid-template-areas:"left center right";align-items:start;gap:16px;display:grid}.g-left{grid-area:left}.g-center{grid-area:center}.g-right{grid-area:right}@media (width<=1080px){.grid3{grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"center center""left right"}}@media (width<=700px){.grid3{grid-template-columns:1fr;grid-template-areas:"center""left""right"}}.tl-scroll{max-height:460px;margin-right:-4px;padding-right:6px;overflow-y:auto}.kv{justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;display:flex}.kv .k{color:var(--muted-fg)}.kv .v{font-weight:500}.srow{border-top:1px solid var(--hair);align-items:center;gap:10px;padding:10px 0;display:flex}.srow:first-of-type{border-top:0;padding-top:2px}.srow .nm{flex:1;min-width:0;font-size:13px;font-weight:500}.fname{vertical-align:bottom;min-width:0;max-width:100%;display:inline-flex}.fname-head{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.fname-tail{white-space:nowrap;flex:none}.dropzone{text-align:center;border:1.5px dashed var(--border);border-radius:var(--r-md);cursor:pointer;color:var(--muted-fg);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:32px 18px;transition:all .12s;display:flex}.dropzone:hover,.dropzone.over{border-color:var(--fg);background:var(--muted);color:var(--fg)}.dropzone svg{width:26px;height:26px}.dropzone .dz-main{color:var(--fg);font-size:14px;font-weight:600}.srow .sub{color:var(--faint);margin-top:1px;font-size:11.5px}.tl{position:relative}.tl:before{content:"";background:var(--hair);width:1px;position:absolute;top:6px;bottom:14px;left:13.5px}.tl-item{gap:13px;padding:0 0 17px;display:flex;position:relative}.tl-item:last-child{padding-bottom:0}.tl-ic{border:1px solid var(--border);color:#52525b;width:28px;height:28px;box-shadow:var(--shadow);background:#fff;border-radius:50%;flex:none;place-items:center;display:grid}.tl-ic svg{width:13px;height:13px}.tl-ic.payment{background:var(--green-bg);color:var(--green);border-color:#bbf7d0}.tl-date{color:var(--faint);font-size:11.5px}.tl-title{margin-top:1px;font-size:13px;font-weight:600}.tl-detail{color:var(--muted-fg);margin-top:2px;font-size:12.5px;line-height:1.5}.src{color:#52525b;background:var(--muted);letter-spacing:.02em;border-radius:999px;align-items:center;margin-top:7px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}.task{align-items:flex-start;gap:14px;display:flex}.task.over{border-color:#f3d0d0}.task.over:before{content:"";background:var(--red);border-radius:2px;width:2.5px;position:absolute;top:14px;bottom:14px;left:0}.task .ic{border-radius:var(--r-md);background:var(--muted);color:#52525b;flex:none;place-items:center;width:38px;height:38px;display:grid}.task .ic svg{width:18px;height:18px}.task.over .ic{background:var(--red-bg);color:var(--red)}.task .ic.warn{background:var(--amber-bg);color:var(--amber)}.task .body{flex:1;min-width:0}.task .acct{letter-spacing:-.01em;font-size:15px;font-weight:600}.task .lbl{color:#52525b;margin-top:1px;font-size:13px;font-weight:500}.task .lbl.over{color:var(--red)}.task .det{color:var(--muted-fg);margin-top:4px;font-size:13px;line-height:1.45}.task .val{flex:none;padding-left:8px;font-size:14px;font-weight:600}.task .val.over{color:var(--red)}.task .actions{flex-wrap:wrap;gap:7px;margin-top:14px;display:flex}.table{border-collapse:collapse;border:1px solid var(--border);border-radius:var(--r-lg);background:#fff;width:100%;overflow:hidden}.table th{text-align:left;color:var(--muted-fg);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:#fcfcfc;padding:11px 14px;font-size:11px;font-weight:600}.table td{border-bottom:1px solid var(--hair);padding:12px 14px;font-size:13px}.table tr:last-child td{border-bottom:0}.table tr.row-link{cursor:pointer}.table tr.row-link:hover td{background:#fafafa}.tbl{-webkit-overflow-scrolling:touch;margin-bottom:11px;overflow-x:auto}@media (width<=640px){.tbl{overflow:visible}.table{box-shadow:none;background:0 0;border:0;border-radius:0;overflow:visible}.table thead{clip:rect(0 0 0 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.table tr{border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);background:#fff;margin-bottom:10px;padding:3px 2px;display:block}.table td{text-align:right;border-bottom:1px solid var(--hair);justify-content:space-between;align-items:center;gap:14px;padding:9px 14px;display:flex}.table tr td:last-child{border-bottom:0}.table td:before{content:attr(data-label);color:var(--muted-fg);text-transform:uppercase;letter-spacing:.04em;text-align:left;white-space:nowrap;flex:none;font-size:11px;font-weight:600}.table td:first-child{font-size:15px;font-weight:600}.table td input:not([type=checkbox]),.table td select{max-width:220px;width:100%!important}.table td[colspan]{justify-content:center}.table td[colspan]:before{content:none}}.spin{border:2px solid var(--border);border-top-color:var(--fg);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spin.sm{border-width:1.5px;width:12px;height:12px;display:inline-block}.save-pill{color:var(--muted-fg);align-items:center;gap:5px;font-size:11.5px;font-weight:500;display:inline-flex}.save-pill svg{width:13px;height:13px}.save-pill.ok{color:var(--green)}.save-pill.err{color:var(--red)}@keyframes spin{to{transform:rotate(360deg)}}.center{place-items:center;min-height:60vh;display:grid}.rise{opacity:0;animation:.5s cubic-bezier(.22,1,.36,1) forwards rise;transform:translateY(7px)}@keyframes rise{to{opacity:1;transform:none}}.crumb{color:var(--faint);margin-bottom:14px;font-size:12.5px}.crumb b{color:var(--muted-fg);font-weight:500}select.input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.modal-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;background:#18181b6b;place-items:center;padding:20px;animation:.15s fade;display:grid;position:fixed;inset:0}@keyframes fade{0%{opacity:0}}.modal{border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-h);background:#fff;width:460px;max-width:100%;max-height:90vh;padding:20px 22px;animation:.25s cubic-bezier(.22,1,.36,1) rise;overflow:auto}@media (width<=640px){.modal-backdrop{padding:12px}.modal{width:100%;min-width:0;max-width:100%;max-height:88vh;padding:18px 16px}.modal .row2{grid-template-columns:1fr;gap:0}.line-row{grid-template-columns:1fr 64px 30px;gap:6px}.modal .foot{background:#fff;padding-bottom:4px;position:sticky;bottom:-18px}}.modal-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.modal-head h3{letter-spacing:-.02em;margin:0;font-size:16px;font-weight:600}.x{cursor:pointer;color:var(--muted-fg);border-radius:var(--r-sm);background:0 0;border:0;place-items:center;width:28px;height:28px;font-size:16px;display:grid}.x:hover{background:var(--muted);color:var(--fg)}.line-row{grid-template-columns:1fr 84px 30px;align-items:center;gap:8px;margin-bottom:8px;display:grid}.line-row .x{width:30px;height:36px}.addline{color:var(--muted-fg);cursor:pointer;align-items:center;gap:6px;padding:6px 0;font-size:12.5px;font-weight:500;display:inline-flex}.addline:hover{color:var(--fg)}.addline svg{width:14px;height:14px}.modal .row2{grid-template-columns:1fr 1fr;gap:12px;display:grid}.modal .foot{gap:8px;margin-top:16px;display:flex}.quicklog-menu{flex-direction:column;gap:2px;display:flex}.quicklog-menu button{text-align:left;width:100%;font:inherit;border-radius:var(--r-md);cursor:pointer;background:0 0;border:0;align-items:center;gap:11px;padding:11px 12px;font-size:14px;font-weight:500;display:flex}.quicklog-menu button:hover{background:var(--muted)}.quicklog-menu .ic{border-radius:var(--r-md);background:var(--muted);color:#52525b;flex:none;place-items:center;width:32px;height:32px;display:grid}.quicklog-menu .ic svg{width:16px;height:16px}.btn-log{margin:4px 0 12px}.toolbar{flex-wrap:wrap;gap:8px;margin:-8px 0 18px;display:flex}.kpis{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;display:grid}@media (width<=920px){.kpis{grid-template-columns:repeat(2,1fr)}}.kpi{border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow);background:#fff;padding:16px}.kpi .big{letter-spacing:-.03em;margin-top:9px;font-size:24px;font-weight:700;display:block}.kpi .sub{color:var(--faint);margin-top:4px;font-size:11.5px}.cols2{grid-template-columns:1fr 1fr;align-items:start;gap:16px;display:grid}@media (width<=880px){.cols2{grid-template-columns:1fr}}.bar-row{align-items:center;gap:12px;padding:8px 0;display:flex}.bar-row .nm{white-space:nowrap;text-overflow:ellipsis;flex:none;width:150px;font-size:13px;font-weight:500;overflow:hidden}.bar-track{background:var(--muted);border-radius:99px;flex:1;height:8px;overflow:hidden}.bar-fill{background:var(--primary);border-radius:99px;height:100%}.bar-row .v{text-align:right;width:86px;font-size:12.5px;font-weight:500}.tabs{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:2px;margin-bottom:22px;display:flex}.tabs button{font:inherit;color:var(--muted-fg);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:13.5px;font-weight:500}.tabs button:hover{color:var(--fg)}.tabs button.on{color:var(--fg);border-bottom-color:var(--fg)}.daytabs{align-items:stretch;gap:6px;margin-bottom:16px;display:flex;overflow:hidden}.daytabs-track{flex:1;gap:6px;min-width:0;display:flex;overflow:hidden}.daytabs-track.day-next{animation:.22s day-next}.daytabs-track.day-prev{animation:.22s day-prev}@keyframes day-next{0%{opacity:.35;transform:translate(26px)}to{opacity:1;transform:none}}@keyframes day-prev{0%{opacity:.35;transform:translate(-26px)}to{opacity:1;transform:none}}.daytab{border:1px solid var(--border);border-radius:var(--r-md);min-width:0;font:inherit;color:var(--muted-fg);white-space:nowrap;text-align:center;-webkit-user-select:none;user-select:none;opacity:.72;text-overflow:ellipsis;background:#fff;flex:1 1 0;padding:9px 10px;font-size:13px;font-weight:500;transition:all .12s;overflow:hidden}.daytab.on{color:var(--fg);border-color:var(--fg);box-shadow:inset 0 -2px 0 var(--fg);opacity:1;font-weight:600}.acct-link{cursor:pointer}.acct-link:hover{text-decoration:underline}.trk-link{font:inherit;color:var(--fg);background:var(--muted);border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:6px;padding:4px 9px;font-size:12px;font-weight:500;display:inline-flex}.trk-link:hover{border-color:#d4d4d8}.trk-link svg{width:13px;height:13px}.task-right{flex-direction:column;flex:none;align-items:flex-end;gap:8px;display:flex}.task-right .row-kebab>button{opacity:.5;font-size:18px;line-height:1}.task-right .row-kebab>button:hover{opacity:1}@media (width<=640px){.daytabs-track .daytab:nth-child(4){display:none}.task.done-row{flex-wrap:wrap;row-gap:6px}.task.done-row .body{flex:calc(100% - 52px)}.task.done-row .faint,.task.done-row .val{text-align:left;flex-basis:100%;padding-left:52px}}.daytab.today{background:var(--muted)}.daytab.today.on{background:#fff}.daytab-n{color:var(--muted-fg);font-weight:500}.daytab.on .daytab-n{color:var(--fg)}.daytab-arrow{border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;width:34px;color:var(--muted-fg);background:#fff;flex:none;place-items:center;display:grid}.daytab-arrow:hover{color:var(--fg);border-color:#d4d4d8}.daytab-arrow svg{width:16px;height:16px}.task.done-row{opacity:.82;align-items:center}.task.done-row .ic{background:var(--muted);color:var(--muted-fg)}.invite-link{background:var(--muted);border-radius:var(--r-md);font-family:var(--mono);word-break:break-all;margin-top:10px;padding:11px 12px;font-size:11.5px;line-height:1.5}.feed-item{border-bottom:1px solid var(--hair);align-items:baseline;gap:12px;padding:11px 0;display:flex}.feed-item:last-child{border-bottom:0}.feed-kind{color:#52525b;background:var(--muted);border-radius:999px;flex:none;padding:2px 8px;font-size:11px;font-weight:600}.feed-main{flex:1;min-width:0}.feed-meta{white-space:nowrap;flex:none}@media (width<=640px){.feed-item{flex-wrap:wrap;align-items:center;gap:4px 10px}.feed-kind{order:1}.feed-meta{order:2;margin-left:auto}.feed-main{overflow-wrap:anywhere;flex-basis:100%;order:3}.table td.sup-name{text-align:left;overflow-wrap:anywhere;display:block}.table td.sup-name:before{content:none}}.section-h{margin:0 0 14px;font-size:13px;font-weight:600}.filterbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.search{flex:1;min-width:200px;max-width:340px;position:relative}.search>svg{width:15px;height:15px;color:var(--faint);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search input{padding-left:33px}.filterbar select.input{flex:none;max-width:175px}.filterbar .grow{flex:1}.chip{font:inherit;cursor:pointer;background:var(--card);border:1px solid var(--border);color:var(--muted-fg);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:500}.chip:hover{background:var(--muted);color:var(--fg)}.chip.on{background:var(--primary);border-color:var(--primary);color:var(--primary-fg)}.count{color:var(--faint);font-size:12px}.rt-toolbar{flex-wrap:wrap;align-items:center;gap:4px;margin-bottom:8px;display:flex}.rt-btn{border:1px solid var(--border);border-radius:var(--r-sm);cursor:pointer;min-width:28px;height:26px;color:var(--fg);background:#fff;justify-content:center;align-items:center;padding:0 7px;font-size:12px;display:inline-flex}.rt-btn:hover{background:var(--muted)}.rt-btn.on{background:var(--fg);color:#fff;border-color:var(--fg)}.rt-btn svg{fill:none;stroke:currentColor;stroke-width:2px;stroke-linecap:round;width:13px;height:13px}.rt-sep{background:var(--border);width:1px;height:18px;margin:0 3px}.rt-area{border:1px solid var(--border);border-radius:var(--r-md);background:#fff;outline:none;min-height:150px;max-height:340px;padding:10px 12px;font-size:13px;line-height:1.6;overflow-y:auto}.rt-area:focus{outline:2px solid var(--fg);outline-offset:-1px}.rt-area p{margin:0 0 4px}.rt-area ul,.rt-area ol{margin:4px 0;padding-left:22px}.rt-area li{margin:1px 0}.rt-area li p{margin:0}.rt-area p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--faint);float:left;pointer-events:none;height:0}.led-in{color:var(--green);font-weight:600}.led-out{color:var(--red);font-weight:600}.file-thumb{border-radius:var(--r-sm);background:var(--muted);cursor:pointer;flex:none;place-items:center;width:40px;height:40px;display:grid;overflow:hidden}.file-thumb img{object-fit:cover;width:100%;height:100%}.file-thumb svg{width:17px;height:17px;color:var(--muted-fg)}.contact{border-top:1px solid var(--hair);padding:13px 0}.contact:first-of-type{border-top:0;padding-top:2px}.contact:last-of-type{padding-bottom:2px}.contact-head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.contact-name{align-items:center;gap:7px;min-width:0;font-size:13.5px;font-weight:600;display:flex}.contact-actions{opacity:0;flex:none;gap:1px;margin:-3px -4px 0 0;transition:opacity .12s;display:flex}.contact:hover .contact-actions{opacity:1}@media (hover:none){.contact-actions{opacity:1}}.contact-line{margin-top:4px;font-size:12.5px;line-height:1.5}.contact-line.muted{color:var(--muted-fg)}.contact-link{color:var(--fg);align-items:baseline;gap:7px;display:flex}.contact-link:hover{color:var(--primary)}.contact-link:hover .ext{opacity:1}.contact-channel{letter-spacing:.04em;text-transform:uppercase;color:var(--faint);border:1px solid var(--border);border-radius:var(--r-sm);flex:none;padding:1px 6px;font-size:10px;font-weight:600}.contact-handle{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.contact-link .ext{color:var(--faint);opacity:0;flex:none;transition:opacity .12s}.tag-xs{padding:1px 6px;font-size:9.5px}.addr{border-top:1px solid var(--hair);padding:13px 0}.addr:first-of-type{border-top:0;padding-top:2px}.addr:last-of-type{padding-bottom:2px}.addr-head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.addr-label{align-items:center;gap:7px;font-size:13.5px;font-weight:600;display:flex}.addr-line{margin-top:4px;font-size:12.5px;line-height:1.55}.addr-line.muted{color:var(--muted-fg)}.conv{border-top:1px solid var(--hair);padding:13px 0}.conv:first-child{border-top:0}.conv .meta{align-items:baseline;gap:8px;margin-bottom:3px;display:flex}.conv .body{font-size:13.5px;line-height:1.5}.price-row{align-items:flex-start;gap:6px;display:flex}.price-x{opacity:0;flex:none;margin-top:22px;transition:opacity .12s}.price-row:hover .price-x{opacity:1}@media (hover:none){.price-x{opacity:1}}.sku-add{position:relative}.sku-add-backdrop{z-index:30;position:fixed;inset:0}.sku-add-pop{z-index:31;border:1px solid var(--border);border-radius:var(--r-md);width:290px;max-width:78vw;box-shadow:var(--shadow-h);background:#fff;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.sku-add-search{border-bottom:1px solid var(--hair);align-items:center;gap:7px;padding:8px 10px;display:flex}.sku-add-search svg{width:15px;height:15px;color:var(--faint);flex:none}.sku-add-search .input{height:auto;box-shadow:none;border:0;padding:2px 0}.sku-add-list{max-height:240px;padding:4px;overflow-y:auto}.sku-add-item{text-align:left;border-radius:var(--r-sm);cursor:pointer;background:0 0;border:0;justify-content:space-between;align-items:baseline;gap:10px;width:100%;padding:8px 9px;font-size:13px;display:flex}.sku-add-item:hover{background:var(--muted)}.sku-add-item .nm{font-weight:500}.sku-add-item .num{font-size:11px}.login{place-items:center;min-height:100vh;display:grid}.login .box{border:1px solid var(--border);border-radius:var(--r-lg);width:360px;box-shadow:var(--shadow-h);background:#fff;padding:28px}.login .brand{padding:0 0 18px}.login h1{letter-spacing:-.02em;margin:0 0 18px;font-size:19px;font-weight:600}.login .err{color:var(--red);margin-top:10px;font-size:12.5px}.login .hint{color:var(--faint);margin-top:14px;font-size:11.5px;line-height:1.5}.tax-tree{font-size:13px}.tax-row{border-radius:var(--r-sm);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;padding:5px 6px;display:flex}.tax-row:hover{background:var(--muted)}.tax-row .chev{width:14px;height:14px;color:var(--faint);flex:none;transition:transform .12s}.tax-row.open .chev{transform:rotate(90deg)}.tax-row svg{width:15px;height:15px;color:var(--muted-fg);flex:none}.tax-label{font-weight:600}.tax-count{color:var(--faint);font-size:11px}.tax-children{border-left:1px solid var(--hair);margin-left:15px;padding-left:9px}.tax-file{border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:8px;padding:6px;display:flex}.tax-file:hover{background:var(--muted)}.tax-file svg{width:14px;height:14px;color:var(--faint);flex:none}.tax-file svg:last-child{opacity:0}.tax-file:hover svg:last-child{opacity:1}.tax-file .nm{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;overflow:hidden}.tax-file .amt{color:var(--muted-fg);flex:none;font-size:12px}.upload-grid{align-items:flex-start;gap:14px;margin-bottom:6px;display:flex}.upload-thumb{border:1px solid var(--border);border-radius:var(--r-md);background:var(--muted);flex:none;justify-content:center;align-items:center;width:96px;height:96px;display:flex;overflow:hidden}.upload-thumb img{object-fit:cover;width:100%;height:100%}.upload-ext{color:var(--muted-fg);flex-direction:column;align-items:center;gap:6px;font-size:11px;font-weight:600;display:flex}.upload-ext svg{width:26px;height:26px}.filename-preview{background:var(--muted);border-radius:var(--r-sm);word-break:break-all;padding:8px 10px;font-size:12.5px}.progress{background:var(--muted);border-radius:4px;height:6px;position:relative;overflow:hidden}.progress>span{background:var(--primary);border-radius:4px;width:40%;height:100%;animation:1.1s ease-in-out infinite indet;position:absolute;left:-40%}@keyframes indet{0%{left:-40%}to{left:100%}}@media (width<=560px){.upload-grid{flex-direction:column}.upload-thumb{width:100%;height:120px}}.web-line{align-items:center;gap:5px;display:flex}.web-open{color:var(--faint);display:inline-flex}.web-open svg{width:13px;height:13px}.web-open:hover{color:var(--primary)}.tagrow{flex-wrap:wrap;gap:4px;display:flex}.tag{color:var(--muted-fg);background:var(--muted);border-radius:var(--r-sm);white-space:nowrap;padding:2px 7px;font-size:10.5px;font-weight:500}.taginput{position:relative}.taginput-box{border:1px solid var(--border);border-radius:var(--r-md);background:#fff;flex-wrap:wrap;align-items:center;gap:5px;min-height:38px;padding:5px 7px;display:flex}.taginput-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #18181b0f}.tag-chip{color:var(--fg);align-items:center;gap:4px;padding:3px 4px 3px 8px;font-size:12px;display:inline-flex}.tag-x{cursor:pointer;color:var(--faint);background:0 0;border:0;padding:0 2px;font-size:14px;line-height:1}.tag-x:hover{color:var(--red)}.taginput-field{min-width:90px;font:inherit;background:0 0;border:0;outline:none;flex:1;padding:4px 2px;font-size:13px}.taginput-pop{z-index:31;border:1px solid var(--border);border-radius:var(--r-md);max-height:200px;box-shadow:var(--shadow-h);background:#fff;padding:4px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.taginput-item{text-align:left;border-radius:var(--r-sm);cursor:pointer;background:0 0;border:0;width:100%;padding:7px 9px;font-size:13px;display:block}.taginput-item:hover{background:var(--muted)}.banner{border-radius:var(--r-md);border:1px solid var(--border);background:var(--card);padding:10px 13px;font-size:12.5px;line-height:1.5}.banner.amber{background:var(--amber-bg);color:#7a4d05;border-color:#f5e3bf}.banner svg{flex:none;width:15px;height:15px}.input.sm{height:30px;padding:0 9px;font-size:12.5px}.invoice-grid{grid-template-columns:minmax(340px,400px) 1fr;align-items:start;gap:18px;display:grid}.invoice-form{flex-direction:column;gap:14px;display:flex}.invoice-preview{border:1px solid var(--border);border-radius:var(--r-md);background:#ececef;max-height:calc(100vh - 32px);padding:16px;position:sticky;top:16px;overflow:auto}.a4-holder{margin:0 auto;position:relative}.a4-scaler{position:absolute;top:0;left:0}.invoice-grid .a4-scaler{position:relative}.inv-line{border-bottom:1px solid var(--border);flex-direction:column;gap:6px;margin-bottom:9px;padding-bottom:9px;display:flex}.inv-line:last-of-type{border-bottom:none;margin-bottom:4px}.inv-line .input{height:32px}.inv-line-fields{grid-template-columns:70px 110px 1fr 26px;align-items:end;gap:6px;display:grid}.inv-fld{flex-direction:column;gap:3px;min-width:0;margin:0;display:flex}.inv-fld>span{color:var(--faint);text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:500}.inv-line-amt{text-align:right;color:var(--muted-fg);font-size:12.5px}.inv-ship{border-top:1px solid var(--border);grid-template-columns:1fr 130px;align-items:center;gap:6px;padding-top:9px;display:grid}.inv-ship .input{height:32px}@media (width<=860px){.invoice-grid{grid-template-columns:1fr}.invoice-preview{max-height:none;position:static}}@media print{.sidebar,.fab,.no-print{display:none!important}.app{display:block}.main,.content{max-width:none!important;margin:0!important;padding:0!important}.invoice-preview{background:#fff!important;border:0!important;max-height:none!important;padding:0!important;position:static!important;overflow:visible!important}.a4-holder{width:auto!important;height:auto!important}.a4-scaler{box-shadow:none!important;position:static!important;transform:none!important}.a4-page{box-shadow:none!important}@page{size:A4;margin:0}}.ship-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.stat-strip{flex-wrap:wrap;gap:10px;margin:2px 0 14px;display:flex}.stat{background:var(--card);border:1px solid var(--border);border-radius:10px;min-width:130px;padding:9px 14px}.stat-k{color:var(--muted-fg);text-transform:uppercase;letter-spacing:.04em;font-size:11px;display:block}.stat-v{margin-top:2px;font-size:18px;font-weight:650;display:block}.timeline{flex-direction:column;display:flex}.tl-row{gap:11px;padding:5px 0 5px 2px;display:flex}.tl-dot{background:var(--fg,#18181b);width:9px;height:9px;box-shadow:0 0 0 3px var(--card);border-radius:50%;flex:none;margin-top:4px}.tl-row+.tl-row .tl-dot{position:relative}.tl-row+.tl-row .tl-dot:before{content:"";background:var(--border);width:1px;height:14px;position:absolute;top:-14px;left:4px}.ship-card{flex-direction:column;gap:10px;display:flex}.ship-card-head{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.ship-addr{font-size:12.5px;line-height:1.5}.ship-items{border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;gap:3px;padding:8px 0;font-size:13px;display:flex}.ship-item .num{color:var(--muted-fg);margin-right:4px}.ship-note{color:var(--muted-fg);background:var(--muted);border-radius:var(--r-sm);white-space:pre-line;padding:7px 9px;font-size:12px}.ship-docs{flex-wrap:wrap;gap:6px;display:flex}.ship-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.ship-shipped{font-size:12.5px;line-height:1.6}.packing-slip{padding:8px 4px}.packing-table{border-collapse:collapse;width:100%;font-size:12.5px}.packing-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--muted-fg);border-bottom:1px solid var(--border);padding:4px 6px;font-size:10px}.packing-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:6px}@media print{body *{visibility:hidden!important}.print-area,.print-area *{visibility:visible!important}.print-area{background:#fff;margin:0;padding:28px;position:fixed;inset:0}.no-print{display:none!important}}
