@import "https://fonts.googleapis.com/css2?family=Libre+Franklin:wght@400;500;600;700&family=Hanken+Grotesk:wght@400;500;600&display=swap";@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:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-dark:oklch(97% .004 250);--color-surface:oklch(100% 0 0);--color-primary:oklch(38% .1 250);--color-accent:oklch(56% .12 230);--color-muted:oklch(62% .02 250);--color-ink:oklch(24% .02 250);--font-heading:"Libre Franklin", sans-serif;--font-body:"Hanken Grotesk", 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 components;@layer utilities{.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}.dark{--color-dark:oklch(18% .018 250);--color-surface:oklch(23.5% .02 250);--color-primary:oklch(78% .09 235);--color-accent:oklch(72% .11 210);--color-muted:oklch(74% .018 250);--color-ink:oklch(94% .006 250)}:root{--sunk:#eaedef}@supports (color:color-mix(in lab, red, red)){:root{--sunk:color-mix(in oklch, var(--color-dark), var(--color-ink) 4%)}}:root{--line:#1820291f}@supports (color:color-mix(in lab, red, red)){:root{--line:color-mix(in oklch, var(--color-ink), transparent 88%)}}:root{--line-2:#18202912}@supports (color:color-mix(in lab, red, red)){:root{--line-2:color-mix(in oklch, var(--color-ink), transparent 93%)}}:root{--shadow:0 1px 1px #0e1c370a, 0 22px 60px #142b5013;--shadow-sm:0 1px 1px #0e1c3709, 0 10px 28px #142b500e;--red:oklch(58% .17 27);--mint:oklch(70% .13 160);--amber:oklch(76% .14 80)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:var(--color-dark);color:var(--color-ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0;line-height:1.35}button,input,select{font:inherit}a{color:inherit;text-decoration:none}h1,h2,h3,.heading{font-family:var(--font-heading);letter-spacing:-.025em}.tnum{font-variant-numeric:tabular-nums}.micro{letter-spacing:.15em;text-transform:uppercase;color:var(--color-muted);font-size:11px;font-weight:800}.app{background:var(--color-dark);grid-template-columns:86px minmax(0,1fr);min-height:100vh;display:grid}.rail{background:#fcfdfd;height:100vh;position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.rail{background:color-mix(in oklch, var(--color-surface), var(--color-dark) 22%)}}.rail{border-right:1px solid var(--line);z-index:20;flex-direction:column;align-items:center;gap:8px;padding:22px 0;display:flex}.logo{background:linear-gradient(145deg,#0a4373,#073154);border-radius:15px;width:46px;height:46px}@supports (color:color-mix(in lab, red, red)){.logo{background:linear-gradient(145deg, color-mix(in oklch, var(--color-primary), black 2%), color-mix(in oklch, var(--color-primary), black 28%))}}.logo{color:#fff;flex:none;place-items:center;display:grid;box-shadow:0 16px 34px #244a8047}.logo svg{width:28px;height:28px}.wordmark{font-family:var(--font-heading);font-weight:800;display:none}.navitem{width:46px;height:46px;color:var(--color-muted);border-radius:14px;place-items:center;transition:transform .18s,background .18s,color .18s;display:grid;position:relative}.navitem svg{width:21px;height:21px}.navitem:hover,.navitem:focus-visible{background:#0a44751a;transform:translateY(-1px)}@supports (color:color-mix(in lab, red, red)){.navitem:hover,.navitem:focus-visible{background:color-mix(in oklch, var(--color-primary), transparent 90%)}}.navitem:hover,.navitem:focus-visible{outline:2px solid #0a44754d}@supports (color:color-mix(in lab, red, red)){.navitem:hover,.navitem:focus-visible{outline:2px solid color-mix(in oklch, var(--color-primary), transparent 70%)}}.navitem:hover,.navitem:focus-visible{outline-offset:2px}.navitem.on{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm);border:1px solid var(--line-2)}.navitem.on:before{content:"";background:var(--color-accent);border-radius:5px;width:4px;height:25px;position:absolute;left:-21px}.spacer{margin-top:auto}.avatar{object-fit:cover;border:3px solid var(--color-surface);border-radius:50%;width:42px;height:42px;box-shadow:0 10px 24px #142b501f}.main{min-width:0}.topbar{border-bottom:1px solid var(--line);background:#fffc;justify-content:space-between;align-items:center;gap:16px;height:78px;padding:0 44px;display:flex}@supports (color:color-mix(in lab, red, red)){.topbar{background:color-mix(in oklch, var(--color-surface), transparent 20%)}}.topbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10;position:sticky;top:0}.search{border:1px solid var(--line);background:var(--color-surface);width:min(360px,42vw);height:42px;color:var(--color-muted);border-radius:12px;align-items:center;gap:10px;padding:0 13px;font-weight:700;display:flex}.top-actions{align-items:center;gap:10px;display:flex}.icon,.btn,.select{background:var(--color-surface);border:1px solid var(--line);min-height:42px;color:var(--color-ink);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 13px;font-weight:800;transition:transform .18s,box-shadow .18s,background .18s;display:inline-flex}.icon{width:42px;color:var(--color-primary);padding:0}.icon svg,.search svg{width:18px;height:18px}.btn:hover,.icon:hover,.select:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn:active,.icon:active{transform:scale(.98)}.btn.primary{background:var(--color-primary);color:var(--color-dark);border-color:var(--color-primary);box-shadow:0 12px 26px #264e8b2e}.content{padding:34px 44px 44px}.hero{grid-template-columns:minmax(0,1fr) 410px;align-items:end;gap:28px;margin-bottom:22px;display:grid}.hero h1{max-width:760px;margin:10px 0 16px;font-size:clamp(34px,4vw,48px);line-height:1.02}.hero p{color:var(--color-muted);max-width:610px;margin:0;font-size:16px;font-weight:650}.ledger-card{background:linear-gradient(145deg, var(--color-surface), #eaeef2)}@supports (color:color-mix(in lab, red, red)){.ledger-card{background:linear-gradient(145deg, var(--color-surface), color-mix(in oklch, var(--color-dark), var(--color-primary) 4%))}}.ledger-card{border:1px solid var(--line);box-shadow:var(--shadow);border-radius:22px;min-height:178px;padding:18px;position:relative;overflow:hidden}.ledger-card:after{content:"";border:1px solid #0a447529;width:260px;height:260px;position:absolute;top:-80px;right:-70px}@supports (color:color-mix(in lab, red, red)){.ledger-card:after{border:1px solid color-mix(in oklch, var(--color-primary), transparent 84%)}}.ledger-card:after{border-radius:50%;box-shadow:inset 0 0 0 32px #0a44750a}@supports (color:color-mix(in lab, red, red)){.ledger-card:after{box-shadow:inset 0 0 0 32px color-mix(in oklch, var(--color-primary), transparent 96%)}}.ledger-row{border-bottom:1px solid var(--line-2);z-index:1;justify-content:space-between;gap:20px;padding:11px 0;display:flex;position:relative}.ledger-row:last-child{border-bottom:0}.ledger-row b{font-family:var(--font-heading);font-size:17px}.ledger-row span{color:var(--color-muted);font-weight:700}.kpi-band{background:var(--color-surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:18px;grid-template-columns:repeat(5,1fr);margin-bottom:22px;display:grid;overflow:hidden}.kpi{border-right:1px solid var(--line);min-height:126px;padding:20px 20px 18px}.kpi:last-child{border-right:0}.kpi .label{color:var(--color-muted);margin-bottom:15px;font-size:12px;font-weight:800}.kpi .value{font-family:var(--font-heading);letter-spacing:-.03em;font-size:clamp(24px,2.4vw,32px);font-weight:800}.delta{color:var(--color-muted);margin-top:7px;font-size:12.5px;font-weight:800}.up{color:var(--mint)}.warn{color:var(--amber)}.bad{color:var(--red)}.grid{gap:18px;display:grid}.dashboard-grid{grid-template-columns:1.65fr .95fr}.settings-grid{grid-template-columns:1.08fr .92fr;align-items:start}.panel{background:var(--color-surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);border-radius:18px;overflow:hidden}.panel-head,.tablebar{justify-content:space-between;align-items:center;gap:16px;padding:19px 22px 12px;display:flex}.panel-head h2,.panel-head h3{margin:0;font-size:18px}.seg,.filters{flex-wrap:wrap;gap:6px;display:flex}.seg{background:var(--sunk);border-radius:12px;padding:3px}.seg button,.pill{color:var(--color-muted);cursor:pointer;background:0 0;border:0;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:850}.seg .on,.pill.on{background:var(--color-primary);color:var(--color-dark);box-shadow:0 1px 2px #142b501a}.chart{padding:8px 20px 20px}.chart svg{width:100%;height:auto;overflow:visible}.draw{stroke-dasharray:900;stroke-dashoffset:900px;animation:1.2s cubic-bezier(.22,1,.36,1) forwards draw}@keyframes draw{to{stroke-dashoffset:0}}.legend{color:var(--color-muted);gap:16px;font-size:12px;font-weight:800;display:flex}.legend i{vertical-align:-1px;border-radius:3px;width:10px;height:10px;margin-right:7px;display:inline-block}.client-list{padding:0 22px 16px}.client,.mobile-row{border-bottom:1px solid var(--line-2);grid-template-columns:42px 1fr auto;align-items:center;gap:12px;padding:14px 0;display:grid}.client:last-child{border-bottom:0}.client img{object-fit:cover;background:var(--color-primary);border-radius:12px;width:42px;height:42px}.client b,.mobile-row b{font-weight:850;display:block}.client span,.mobile-row span,td small{color:var(--color-muted);font-size:12px;font-weight:700}.amount,.invoice-no{color:var(--color-primary);font-weight:900}.tablebar{border-bottom:1px solid var(--line);padding:20px 22px}.table-wrap{max-height:620px;overflow:auto}table{border-collapse:separate;border-spacing:0;width:100%}th{z-index:2;background:#fefefe;position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){th{background:color-mix(in oklch, var(--color-surface), var(--color-dark) 12%)}}th{color:var(--color-muted);letter-spacing:.13em;text-transform:uppercase;text-align:left;border-bottom:1px solid var(--line);cursor:pointer;padding:13px 22px;font-size:11px;font-weight:900}td{border-bottom:1px solid var(--line-2);padding:15px 22px;font-weight:700}tr:hover td{background:#0a44750d}@supports (color:color-mix(in lab, red, red)){tr:hover td{background:color-mix(in oklch, var(--color-primary), transparent 95%)}}.status{border-radius:999px;padding:5px 10px;font-size:12px;font-weight:900;display:inline-flex}.paid{background:var(--mint)}@supports (color:color-mix(in lab, red, red)){.paid{background:color-mix(in oklch, var(--mint), transparent 83%)}}.paid{color:var(--mint)}@supports (color:color-mix(in lab, red, red)){.paid{color:color-mix(in oklch, var(--mint), var(--color-ink) 22%)}}.sent{background:#0a447524}@supports (color:color-mix(in lab, red, red)){.sent{background:color-mix(in oklch, var(--color-primary), transparent 86%)}}.sent{color:var(--color-primary)}.draft{background:#7d879229}@supports (color:color-mix(in lab, red, red)){.draft{background:color-mix(in oklch, var(--color-muted), transparent 84%)}}.draft{color:var(--color-muted)}.overdue{background:var(--red)}@supports (color:color-mix(in lab, red, red)){.overdue{background:color-mix(in oklch, var(--red), transparent 84%)}}.overdue{color:var(--red)}.page-title{justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:22px;display:flex}.page-title h1{margin:8px 0 0;font-size:clamp(34px,3.5vw,42px);line-height:1}.form-section{border-bottom:1px solid var(--line);padding:22px}.form-section:last-child{border-bottom:0}.form-section h2,.form-section h3{margin:0 0 16px;font-size:17px}.fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.field label{color:var(--color-muted);margin:0 0 7px;font-size:12px;font-weight:900;display:block}.input,input.input,select.input{border:1px solid var(--line);background:#fefefe;border-radius:12px;width:100%;height:43px}@supports (color:color-mix(in lab, red, red)){.input,input.input,select.input{background:color-mix(in oklch, var(--color-surface), var(--color-dark) 8%)}}.input,input.input,select.input{color:var(--color-ink);justify-content:space-between;align-items:center;padding:0 12px;font-weight:750;display:flex}.switches{gap:10px;display:grid}.switch{border:1px solid var(--line);background:var(--color-surface);border-radius:13px;justify-content:space-between;align-items:center;gap:16px;padding:13px 14px;display:flex}.toggle{background:var(--color-primary);border:0;border-radius:999px;flex:none;width:42px;height:24px;position:relative}.toggle:after{content:"";background:var(--color-dark);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;right:3px}.toggle.off{background:#7d879299}@supports (color:color-mix(in lab, red, red)){.toggle.off{background:color-mix(in oklch, var(--color-muted), transparent 40%)}}.toggle.off:after{transform:translate(-18px)}.plan{border:1px solid var(--line);border-radius:15px;grid-template-columns:1.2fr .7fr .7fr;display:grid;overflow:hidden}.plan div{border-right:1px solid var(--line);border-bottom:1px solid var(--line-2);padding:14px;font-weight:750}.plan div:nth-child(3n){border-right:0}.plan .headcell{background:#0a44750f}@supports (color:color-mix(in lab, red, red)){.plan .headcell{background:color-mix(in oklch, var(--color-primary), transparent 94%)}}.plan .headcell{color:var(--color-muted);text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:900}.toast{z-index:100;background:var(--color-surface);border:1px solid var(--line);box-shadow:var(--shadow);color:var(--color-ink);border-radius:14px;padding:13px 16px;font-weight:850;position:fixed;bottom:24px;right:24px}.modal-backdrop{z-index:80;background:#0a14236b;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{background:var(--color-surface);border:1px solid var(--line);width:min(560px,100%);box-shadow:var(--shadow);border-radius:18px;overflow:hidden}.skeleton{background:linear-gradient(90deg,#7d87921f,#7d87920a,#7d87921f)}@supports (color:color-mix(in lab, red, red)){.skeleton{background:linear-gradient(90deg, color-mix(in oklch, var(--color-muted), transparent 88%), color-mix(in oklch, var(--color-muted), transparent 96%), color-mix(in oklch, var(--color-muted), transparent 88%))}}.skeleton{background-size:220% 100%;border-radius:12px;min-height:18px;animation:1.2s infinite shimmer}@keyframes shimmer{to{background-position:-220% 0}}.mobile-nav{display:none}.footer{color:var(--color-muted);padding:16px 44px 28px;font-size:12px;font-weight:800}.footer a{color:var(--color-primary)}@media (width<=980px){.app{grid-template-columns:1fr;padding-bottom:78px}.rail{display:none}.topbar{height:70px;padding:0 18px}.wordmark{display:block}.search{display:none}.content{padding:24px 18px}.hero,.dashboard-grid,.settings-grid,.kpi-band{grid-template-columns:1fr}.kpi{border-right:0;border-bottom:1px solid var(--line);min-height:104px}.kpi:last-child{border-bottom:0}.page-title{flex-direction:column;align-items:stretch}.table-wrap table,.table-wrap thead,.table-wrap tbody,.table-wrap tr,.table-wrap td{display:block}.table-wrap thead{display:none}.table-wrap tr{border:1px solid var(--line);background:var(--color-surface);border-radius:14px;margin:12px;overflow:hidden}.table-wrap td{justify-content:space-between;gap:12px;padding:12px 14px;display:flex}.table-wrap td:before{content:attr(data-label);color:var(--color-muted);text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:900}.fields{grid-template-columns:1fr}.top-actions .btn:not(.primary),.top-actions .select{display:none}.mobile-nav{background:var(--color-surface);border-top:1px solid var(--line);z-index:50;justify-content:space-around;align-items:center;height:72px;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav a{color:var(--color-muted);place-items:center;gap:3px;min-width:64px;min-height:56px;font-size:10px;font-weight:900;display:grid}.mobile-nav svg{width:21px;height:21px}.mobile-nav a.on{color:var(--color-primary)}.footer{padding:6px 18px 28px}}@media (width<=520px){.hero h1{font-size:34px}.ledger-card{min-height:auto}.panel-head,.tablebar{flex-direction:column;align-items:flex-start}.client{grid-template-columns:42px minmax(0,1fr)}.client .amount,.client .status{grid-column:2;justify-self:start}}
