@import "https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@1&family=Inter+Tight:wght@300;400;500;600;700&family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700&family=JetBrains+Mono:wght@400;500;600&display=swap";@layer components;@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--spacing:.25rem;--radius-sm:6px;--radius-lg:12px;--shadow-xs:0 1px 2px #0f172a0a;--shadow-lg:0 12px 32px #0f172a14, 0 2px 6px #0f172a0a;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--radius:8px;--font-display:"Inter Tight", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.block{display:block}.flex{display:flex}.hidden{display:none}.inline-flex{display:inline-flex}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.border{border-style:var(--tw-border-style);border-width:1px}}:root{--bg:oklch(99% .003 250);--bg-soft:oklch(97.5% .004 250);--bg-sunk:oklch(96% .005 250);--surface:#fff;--border:oklch(92% .005 250);--border-strong:oklch(86% .008 250);--fg:oklch(20% .015 260);--fg-soft:oklch(42% .012 260);--fg-muted:oklch(58% .01 260);--fg-faint:oklch(72% .008 260);--accent:oklch(62% .14 158);--accent-fg:#fff;--accent-soft:oklch(95% .04 158);--accent-border:oklch(82% .1 158);--warn:oklch(70% .14 75);--warn-soft:oklch(96% .04 80);--danger:oklch(58% .18 25);--danger-soft:oklch(96% .03 25);--info:oklch(60% .13 245);--info-soft:oklch(96% .03 245);--radius-sm:6px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-xs:0 1px 2px #0f172a0a;--shadow-sm:0 1px 2px #0f172a0a, 0 1px 1px #0f172a05;--shadow-md:0 4px 12px #0f172a0f, 0 1px 2px #0f172a0a;--shadow-lg:0 12px 32px #0f172a14, 0 2px 6px #0f172a0a;--row-h:36px;--row-h-lg:44px;--font-display:"Inter Tight", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{-webkit-text-size-adjust:100%;height:100%}[data-scroll-behavior=smooth]{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--fg);background:var(--bg);font-feature-settings:"ss01", "cv11";-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;padding:0;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);margin:0;font-size:14px;line-height:1.45}#root{height:100%}button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}input:focus,select:focus,textarea:focus{outline:none}a{color:inherit;text-decoration:none}h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em;margin:0}h1{font-size:22px;font-weight:600}h2{font-size:17px;font-weight:600}h3{letter-spacing:-.01em;font-size:14px;font-weight:600}.mono{font-feature-settings:"tnum";font-family:var(--font-mono)!important}.tabular{font-variant-numeric:tabular-nums}.muted{color:var(--fg-muted)}.faint{color:var(--fg-faint)}.soft{color:var(--fg-soft)}.h-section{text-transform:uppercase;letter-spacing:.06em;color:var(--fg-muted);font-size:12px;font-weight:600}.btn{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);height:32px;color:var(--fg);white-space:nowrap;cursor:pointer;align-items:center;gap:6px;padding:0 12px;font-size:13px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover:not(:disabled){background:var(--bg-soft);border-color:var(--border-strong)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--fg);color:var(--bg);border-color:var(--fg)}.btn-primary:hover:not(:disabled){background:oklch(28% .018 260);border-color:oklch(28% .018 260)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg-soft);border-color:var(--border)}.btn-sm{height:28px;padding:0 10px;font-size:12.5px}.btn-lg{height:38px;padding:0 16px;font-size:14px}.btn-icon{justify-content:center;width:32px;height:32px;padding:0}.btn-icon.btn-sm{width:28px;height:28px}.btn-danger{color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-soft);border-color:var(--danger)}.btn-accent{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.btn-accent:hover:not(:disabled){filter:brightness(.96)}.badge{background:var(--bg-sunk);color:var(--fg-soft);border:1px solid var(--border);letter-spacing:-.005em;white-space:nowrap;border-radius:999px;flex-shrink:0;align-items:center;gap:4px;height:20px;padding:2px 7px;font-size:12px;font-weight:500;display:inline-flex}.badge-dot{background:currentColor;border-radius:999px;flex-shrink:0;width:6px;height:6px}.badge.paid{color:oklch(45% .12 158);background:var(--accent-soft);border-color:var(--accent-border)}.badge.sent{color:oklch(45% .12 245);background:var(--info-soft);border-color:oklch(85% .06 245)}.badge.draft{color:var(--fg-muted)}.badge.overdue{color:oklch(45% .16 25);background:var(--danger-soft);border-color:oklch(82% .09 25)}.badge.partial{color:oklch(48% .13 75);background:var(--warn-soft);border-color:oklch(84% .09 75)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.row{align-items:center;display:flex}.col{flex-direction:column;display:flex}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.spacer{flex:1;min-width:0}.divider{background:var(--border);height:1px}.divider-v{background:var(--border);flex-shrink:0;align-self:stretch;width:1px}.avatar{background:var(--bg-sunk);border:1px solid var(--border);width:24px;height:24px;color:var(--fg-soft);-webkit-user-select:none;user-select:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:inline-flex}.field{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--fg-soft);letter-spacing:-.005em;font-size:12px;font-weight:500}.input,.select-input,.textarea-input{height:var(--row-h);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);width:100%;padding:0 10px;font-size:13.5px;transition:all .12s}.input:hover,.select-input:hover{border-color:var(--border-strong)}.input:focus,.select-input:focus,.textarea-input:focus{border-color:var(--fg);box-shadow:0 0 0 3px oklch(20% .015 260/.08)}.inv-table{border-collapse:collapse;width:100%;font-size:13px}.inv-table th{text-align:left;color:var(--fg-muted);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-soft);padding:8px 12px;font-size:12px;font-weight:500}.inv-table td{border-bottom:1px solid var(--border);padding:10px 12px}.inv-table tr:last-child td{border-bottom:none}.inv-table tbody tr{transition:background .1s}.inv-table tbody tr:hover td{background:var(--bg-soft);cursor:pointer}.inv-table .num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--font-mono)}.sidebar{background:var(--bg-soft);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:220px;height:100%;padding:14px;display:flex}.sidebar .brand{align-items:center;padding:4px 8px 14px;display:flex}.nav-item{height:30px;color:var(--fg-soft);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:6px;align-items:center;gap:10px;width:100%;padding:0 8px;font-size:13px;font-weight:400;text-decoration:none;transition:background .1s,color .1s;display:flex}.nav-item:hover{color:var(--fg);background:oklch(94% .005 250);border-color:#0000}.nav-item.active{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-xs);border-color:var(--border);font-weight:500}.nav-section{color:var(--fg-faint);text-transform:uppercase;letter-spacing:.06em;padding:10px 8px 4px;font-size:11px;font-weight:600}.topbar{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 20px;display:flex}.topbar-crumb{color:var(--fg-muted);align-items:center;gap:6px;font-size:13px;display:flex}.topbar-crumb strong{color:var(--fg);font-weight:500}.app-frame{background:var(--bg);min-height:100dvh;display:flex}@media (width>=768px){.app-frame{height:100dvh;overflow:hidden}.app-main{overflow:hidden}.app-scroll{overflow-y:auto;padding-bottom:0!important}}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}.app-scroll{flex:1;min-height:0}.app-scroll::-webkit-scrollbar{width:10px}.app-scroll::-webkit-scrollbar-track{background:0 0}.app-scroll::-webkit-scrollbar-thumb{border:2px solid var(--bg);background:oklch(88% .005 250);border-radius:999px}.app-scroll::-webkit-scrollbar-thumb:hover{background:oklch(80% .008 250)}.mobile-topbar{border-bottom:1px solid var(--border);background:var(--surface);z-index:10;flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 16px;display:flex;position:sticky;top:0}.mobile-bottom-nav{border-top:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);height:60px;padding-bottom:env(safe-area-inset-bottom);z-index:100;background:#fffffff7;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-btn{color:var(--fg-muted);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:0;font-size:11px;font-weight:500;transition:color .12s;display:flex}.mobile-nav-btn.active{color:var(--fg)}.mobile-nav-btn svg{flex-shrink:0}.mobile-fab{bottom:calc(60px + env(safe-area-inset-bottom) + 12px);z-index:110;background:var(--fg);width:48px;height:48px;color:var(--bg);cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;transition:transform .1s,box-shadow .1s;display:flex;position:fixed;right:16px;box-shadow:0 4px 12px #0f172a40}.mobile-fab:hover{transform:translateY(-1px);box-shadow:0 6px 16px #0f172a4d}.overlay{z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;position:fixed;inset:0}.mobile-drawer{background:var(--bg-soft);z-index:201;width:260px;box-shadow:var(--shadow-lg);transition:transform .2s;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(0)}.mobile-drawer.closed{transform:translate(-100%)}kbd{border:1px solid var(--border-strong);background:var(--surface);min-width:16px;height:16px;font-family:var(--font-mono);color:var(--fg-soft);border-bottom-width:2px;border-radius:3px;justify-content:center;align-items:center;padding:0 4px;font-size:11px;display:inline-flex}.spinner{border:2px solid var(--border-strong);border-top-color:var(--fg);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}.spinner-sm{border-width:1.5px;width:14px;height:14px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.18s ease-out both fadeUp}@keyframes pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.pop{animation:.15s ease-out both pop}.skeleton{background:linear-gradient(90deg, var(--bg-sunk) 25%, var(--bg-soft) 50%, var(--bg-sunk) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.date-field{height:var(--row-h);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);text-align:left;width:100%;color:var(--fg);align-items:center;gap:8px;padding:0 10px;font-size:13.5px;transition:all .12s;display:inline-flex}.date-field:hover:not([data-disabled=true]){border-color:var(--border-strong)}.date-field[data-focused=true]{border-color:var(--fg);box-shadow:0 0 0 3px oklch(20% .015 260/.08)}.date-field[data-disabled=true]{opacity:.6;cursor:not-allowed;background:var(--bg-soft)}.date-field-icon{color:var(--fg-muted);flex-shrink:0}.date-field-input{min-width:0;height:100%;color:var(--fg);background:0 0;border:none;flex:1;padding:0;font-size:13.5px}.date-field-input::placeholder{color:var(--fg-faint)}.date-field-clear{width:20px;height:20px;color:var(--fg-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:inline-flex}.date-field-clear:hover{background:var(--bg-sunk);color:var(--fg)}.date-range-trigger{cursor:pointer}.date-range-segment{white-space:nowrap;text-overflow:ellipsis;font-variant-numeric:tabular-nums;overflow:hidden}.date-range-segment[data-placeholder=true]{color:var(--fg-faint)}.date-popover{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:12px;overflow:hidden}.date-popover .rdp-root{--rdp-accent-color:var(--fg);--rdp-accent-background-color:var(--bg-sunk);--rdp-background-color:var(--surface);--rdp-range_middle-background-color:var(--accent-soft);--rdp-range_middle-color:var(--fg);--rdp-range_start-color:var(--accent-fg);--rdp-range_start-background:var(--accent);--rdp-range_end-color:var(--accent-fg);--rdp-range_end-background:var(--accent);--rdp-selected-border:none;--rdp-today-color:var(--accent);--rdp-day-height:36px;--rdp-day-width:36px;--rdp-day_button-height:32px;--rdp-day_button-width:32px;--rdp-day_button-border-radius:var(--radius);--rdp-weekday-padding:6px 0;--rdp-weekday-text-transform:uppercase;--rdp-weekday-font-size:11px;--rdp-nav-height:32px;--rdp-nav_button-height:28px;--rdp-nav_button-width:28px;--rdp-month_caption-font:600 13.5px var(--font-display);font-family:var(--font-body);color:var(--fg);margin:0}.date-popover .rdp-weekday{color:var(--fg-faint);letter-spacing:.04em;font-weight:600}.date-popover .rdp-day_button{border-radius:var(--radius);font-size:13px;font-weight:500;transition:background .12s}.date-popover .rdp-day_button:hover:not([disabled]){background:var(--bg-soft)}.date-popover .rdp-day_button:focus-visible{outline:2px solid var(--fg);outline-offset:1px}.date-popover .rdp-selected .rdp-day_button{background:var(--fg);color:var(--bg)}.date-popover .rdp-selected .rdp-day_button:hover{background:oklch(28% .018 260)}.date-popover .rdp-range_start .rdp-day_button,.date-popover .rdp-range_end .rdp-day_button{background:var(--accent);color:var(--accent-fg)}.date-popover .rdp-range_middle{background:var(--accent-soft)}.date-popover .rdp-range_middle .rdp-day_button{color:var(--fg);background:0 0;border-radius:0}.date-popover .rdp-range_middle .rdp-day_button:hover{background:oklch(90% .05 158)}.date-popover .rdp-range_start{border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius)}.date-popover .rdp-range_end{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}.date-popover .rdp-today:not(.rdp-selected) .rdp-day_button{color:var(--accent);font-weight:700}.date-popover .rdp-outside .rdp-day_button{color:var(--fg-faint)}.date-popover .rdp-disabled .rdp-day_button{opacity:.35;cursor:not-allowed}.date-popover .rdp-month_caption{text-transform:capitalize;color:var(--fg)}.date-popover .rdp-nav button{border-radius:var(--radius-sm);color:var(--fg-soft);transition:background .12s}.date-popover .rdp-nav button:hover{background:var(--bg-soft);color:var(--fg)}@media (width<=767px){.date-popover{border-bottom-right-radius:0;border-bottom-left-radius:0}.date-popover .rdp-root{--rdp-day-height:42px;--rdp-day-width:100%;--rdp-day_button-height:38px;--rdp-day_button-width:38px}.date-popover .rdp-months,.date-popover .rdp-month,.date-popover .rdp-table{width:100%}}.progress-bar{background:var(--bg-sunk);border-radius:999px;height:6px;display:flex;overflow:hidden}.progress-segment{transition:width .4s}.rich-editor-content{outline:none;padding:10px 12px;font-size:13px;line-height:1.55}.rich-editor-content p{margin:0 0 6px}.rich-editor-content p:last-child{margin-bottom:0}.rich-editor-content ul,.rich-editor-content ol{margin:6px 0;padding-left:24px}.rich-editor-content a{color:var(--accent,#4f46e5);text-decoration:underline}.rich-editor-content p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--muted,#9ca3af);pointer-events:none;height:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
