:root{--paper: #ffffff;--paper-2: #f0f0f3;--surface: #ffffff;--surface-2: #f6f6f8;--ink: #1b1b1f;--ink-2: #55555d;--ink-3: #8a8a93;--line: #ececef;--line-strong: #dcdce1;--accent: #b21f2b;--accent-2: #8c1822;--accent-soft: #f7e1e2;--accent-ink: #6e1219;--teal: #2c7a96;--teal-2: #226176;--teal-soft: #dcecf1;--pos: #2f7d52;--pos-soft: #e2efe6;--neg: #b21f2b;--neg-soft: #f7e1e2;--warn: #b8860b;--warn-soft: #f6ecd2;--info: #2c7a96;--info-soft: #dcecf1;--ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--display: var(--ui);--mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;--r-sm: 8px;--r: 12px;--r-lg: 20px;--shadow-sm: 0 1px 2px rgba(20, 20, 30, .05);--shadow-input: 0 1px 2px rgba(20, 20, 30, .07);--shadow: 0 1px 3px rgba(20, 20, 30, .05), 0 12px 28px -16px rgba(20, 20, 35, .26);--shadow-pop: 0 1px 3px rgba(20, 20, 30, .06), 0 14px 30px -14px rgba(20, 20, 35, .3);--shadow-lg: 0 24px 60px -28px rgba(15, 15, 30, .4);--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--nav-w: 252px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--ui);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}*{-webkit-tap-highlight-color:transparent}.table-wrap,.modal,.drawer,.page{-webkit-overflow-scrolling:touch}@media (hover: none){.btn:hover,.nav-item:hover,table.tbl tbody tr:hover{background:inherit}}h1,h2,h3,h4{font-family:var(--display);font-weight:700;margin:0;letter-spacing:-.02em}a{color:inherit;text-decoration:none}button{font-family:inherit}.mono{font-family:var(--mono)}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.app{display:grid;grid-template-columns:var(--nav-w) 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;border-right:1px solid var(--line);background:linear-gradient(180deg,var(--surface),var(--surface-2));padding:22px 16px;display:flex;flex-direction:column;gap:4px}.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 20px;margin-bottom:8px;border-bottom:1px solid var(--line)}.brand .mark{width:42px;height:42px;flex:none;position:relative;display:grid;place-items:center;color:#fff;font-family:var(--display);font-weight:700;font-size:16px}.brand .mark:before{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:7px;background:linear-gradient(145deg,#c8303d,var(--accent) 55%,var(--accent-2));transform:rotate(45deg);box-shadow:inset 0 1px #ffffff59,var(--shadow-sm)}.brand .mark span{position:relative;z-index:1;letter-spacing:-.02em}.brand-logo{height:46px;width:auto;display:block}.login-brand{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:18px}.login-logo{height:66px;width:auto}.login-sub{font-size:11px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase}.brand .word{line-height:1.1}.brand .word b{font-family:var(--display);font-size:18px;display:block;letter-spacing:-.02em}.brand .word span{font-size:11px;color:var(--ink-3);letter-spacing:.14em;text-transform:uppercase}.nav-group-label{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding:16px 10px 6px;font-weight:700}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--ink-2);font-weight:500;font-size:14px;transition:background .15s,color .15s}.nav-item .ic{width:18px;height:18px;flex:none;opacity:.8}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:600;box-shadow:inset 0 0 0 1px #b6532b29}.nav-item.active .ic{opacity:1}.nav-spacer{flex:1}.nav-user{margin-top:8px;padding:10px;border-top:1px solid var(--line);display:flex;align-items:center;gap:10px}.avatar{width:34px;height:34px;border-radius:50%;flex:none;background:var(--ink);color:var(--paper);display:grid;place-items:center;font-weight:600;font-size:13px}.main{min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:18px 28px;background:linear-gradient(180deg,#c8303d,var(--accent));border-bottom:none;box-shadow:0 6px 20px -8px #b21f2b8c;color:#fff}.topbar .page-title{color:#fff}.topbar .page-sub{color:#ffffffeb}.topbar .btn{color:#fff;background:#ffffff24;border-color:#fff6;box-shadow:none}.topbar .btn:hover{background:#ffffff3d;border-color:#fff9}.topbar .btn.ghost{background:transparent;border-color:transparent}.topbar .btn.ghost:hover{background:#ffffff29}.topbar .btn.primary{background:#fff;color:var(--accent);border-color:#fff}.topbar .btn.primary:hover{background:#fff;opacity:.92}.topbar-titlebox{flex:1;min-width:0}.topbar .page-title{font-size:24px;font-weight:700;letter-spacing:-.02em;color:#fff;overflow:hidden;text-overflow:ellipsis}.topbar .page-sub{color:#ffffffeb;font-size:13px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-btn .ic{width:24px;height:24px}.topbar-actions{margin-left:auto;display:flex;gap:10px;align-items:center}.page{padding:26px 28px 80px;max-width:1180px;width:100%}.page-narrow{max-width:820px}.menu-btn,.mobile-nav{display:none}.card{background:var(--surface);border:1px solid #f1f1f4;border-radius:var(--r-lg);box-shadow:var(--shadow)}.card-pad{padding:20px}.card-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}.card-head h3{font-size:17px}.card-head .sub{color:var(--ink-3);font-size:12.5px}.card-head .right{margin-left:auto;display:flex;gap:8px;align-items:center}.grid{display:grid;gap:16px}.cols-2{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(3,1fr)}.cols-4{grid-template-columns:repeat(4,1fr)}.split{display:grid;gap:16px;grid-template-columns:1.6fr 1fr}.stat{padding:18px 20px;position:relative;overflow:hidden}.stat-row{display:flex;align-items:center;gap:14px}.stat-main{flex:1;min-width:0}.stat .spark{flex:none;align-self:center;opacity:.95}.stat-ic{width:50px;height:50px;border-radius:15px;flex:none;display:grid;place-items:center;background:var(--surface-2);color:var(--ink-3)}.stat-ic .ic{width:24px;height:24px}.stat.pos .stat-ic{background:var(--pos-soft);color:var(--pos)}.stat.neg .stat-ic{background:var(--neg-soft);color:var(--neg)}.stat.info .stat-ic{background:var(--teal-soft);color:var(--teal)}@media (max-width: 380px){.stat .spark{display:none}}.stat .label{font-size:12px;color:var(--ink-3);font-weight:600;letter-spacing:.03em;text-transform:uppercase}.stat .value{font-family:var(--display);font-size:30px;font-weight:700;margin-top:8px;letter-spacing:-.03em;white-space:nowrap}.stat .value small{font-size:16px;color:var(--ink-3);font-weight:500}.stat .delta{margin-top:8px;font-size:12.5px;display:inline-flex;gap:5px;align-items:center}.stat .accent-bar{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}.stat.pos .accent-bar{background:var(--pos)}.stat.neg .accent-bar{background:var(--neg)}.stat.info .accent-bar{background:var(--info)}.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);font-weight:600;font-size:13.5px;padding:9px 15px;border-radius:10px;cursor:pointer;transition:transform .08s,background .15s,border-color .15s,box-shadow .15s;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--ink-3)}.btn:active{transform:translateY(1px)}.btn .ic{width:16px;height:16px}.btn.primary{background:linear-gradient(180deg,#c8303d,var(--accent));color:#fff;border-color:var(--accent-2);box-shadow:0 1px #ffffff38 inset,var(--shadow-sm)}.btn.primary:hover{background:linear-gradient(180deg,#be2733,var(--accent-2))}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:var(--surface-2)}.btn.danger{color:var(--neg);border-color:var(--neg-soft)}.btn.danger:hover{background:var(--neg-soft);border-color:var(--neg)}.btn.danger.fill{background:var(--neg);color:#fff;border-color:var(--accent-2);box-shadow:0 1px #fff3 inset,var(--shadow-sm)}.btn.danger.fill:hover{background:var(--accent-2)}.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px}.btn.icon{padding:8px}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}.badge.pos{background:var(--pos-soft);color:var(--pos);border-color:transparent}.badge.neg{background:var(--neg-soft);color:var(--neg);border-color:transparent}.badge.warn{background:var(--warn-soft);color:var(--warn);border-color:transparent}.badge.info{background:var(--info-soft);color:var(--info);border-color:transparent}.badge.accent{background:var(--accent-soft);color:var(--accent-ink);border-color:transparent}.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}table.tbl th{text-align:left;font-weight:600;color:var(--ink-3);font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;padding:11px 16px;border-bottom:1px solid var(--line);white-space:nowrap}table.tbl td{padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle}table.tbl tr:last-child td{border-bottom:none}table.tbl tbody tr{transition:background .12s}table.tbl tbody tr:hover{background:var(--surface-2)}.t-right{text-align:right}.t-center{text-align:center}.t-name{font-weight:600}.t-muted{color:var(--ink-3)}.row-click{cursor:pointer}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12.5px;font-weight:600;color:var(--ink-2)}.field .hint{font-size:11.5px;color:var(--ink-3)}.input,.select,textarea.input{font-family:inherit;font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;padding:10px 12px;width:100%;box-shadow:var(--shadow-input);transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input.num{font-variant-numeric:tabular-nums}.input-prefix{position:relative}.input-prefix .pfx{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--ink-3);font-size:13px}.input-prefix .input{padding-left:38px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.stepper{display:flex;align-items:center;gap:6px}.stepper .step{width:36px;height:40px;flex:none;border:1px solid var(--line-strong);background:var(--surface);border-radius:9px;font-size:18px;font-weight:600;color:var(--ink-2);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-input)}.stepper .step:hover{background:var(--surface-2)}.stepper .step:active{transform:translateY(1px)}.stepper .step:disabled{opacity:.4;cursor:not-allowed}.stepper .step.edit{color:var(--ink-3)}.stepper .step.edit .ic{width:15px;height:15px}.stepper .val{flex:1;min-width:0;height:40px;display:inline-flex;align-items:center;justify-content:center;gap:4px;border:1px solid transparent;border-radius:9px;background:var(--surface-2);font:inherit;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);cursor:pointer;padding:0 8px}.stepper .val em{font-style:normal;color:var(--ink-3);font-size:12px;font-weight:500}.stepper input.val{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);cursor:text;outline:none;text-align:center}@media (max-width: 600px){.stepper .step{width:42px;height:44px}.stepper .val{height:44px;font-size:16px}}.line-item{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.line-item .li-mat{grid-column:1 / -1;min-width:0}.line-item .li-qty,.line-item .li-cost{grid-column:1 / -1}.line-item .li-sub{font-size:13px;color:var(--ink-2);white-space:nowrap;align-self:center}.line-item .li-del{justify-self:end}@media (min-width: 600px){.line-item{display:flex;flex-wrap:nowrap;gap:8px;align-items:center}.line-item .li-mat{flex:2 1 0}.line-item .li-qty{flex:1.4 1 150px}.line-item .li-cost{flex:1.2 1 130px}.line-item .li-sub{flex:0 0 auto;min-width:84px;text-align:right}}.search{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;padding:8px 12px;min-width:200px;box-shadow:var(--shadow-input)}.filters-bar{display:flex;flex-direction:column;gap:10px}.filters-bar .search{width:100%;min-width:0}.filters-bar .sel-wrap,.filters-bar .daterange{width:100%}.filters-bar .sel-wrap.inline .sel-trigger{width:100%;min-width:0}.filters-bar .seg{display:flex}.filters-bar .seg button{flex:1}@media (min-width: 720px){.filters-bar{flex-direction:row;align-items:center}.filters-bar .search{flex:1 1 220px;width:auto}.filters-bar .sel-wrap,.filters-bar .daterange{width:auto}.filters-bar .sel-wrap.inline .sel-trigger{width:auto;min-width:170px}.filters-bar .seg{margin-left:auto}.filters-bar .seg button{flex:none}}.search input{border:none;background:none;outline:none;font:inherit;width:100%}.search .ic{width:16px;height:16px;color:var(--ink-3)}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:2px;box-shadow:var(--shadow-input)}.seg button{border:none;background:none;padding:7px 13px;border-radius:8px;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#281a1057;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:20px;animation:fade .15s ease}.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:90vh;overflow:auto;animation:pop .18s cubic-bezier(.2,.9,.3,1.2)}.modal.wide{max-width:760px}.modal-head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}.modal-head h3{font-size:19px}.modal-head .sub{font-size:12.5px;color:var(--ink-3);margin-top:2px}.modal-body{padding:22px}.modal-foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;border-top:1px solid var(--line);background:var(--surface-2);position:sticky;bottom:0}@keyframes fade{0%{opacity:0}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}}@keyframes rise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.row{display:flex;align-items:center;gap:10px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.wrap-gap{display:flex;flex-wrap:wrap;gap:10px}.muted{color:var(--ink-3)}.tiny{font-size:12px}.w-auto{width:auto}.flex-1{flex:1}.mt-2{margin-top:var(--s-2)}.mt-3{margin-top:var(--s-3)}.mb-2{margin-bottom:var(--s-2)}.mb-3{margin-bottom:var(--s-3)}.mb-4{margin-bottom:var(--s-4)}.mb-5{margin-bottom:var(--s-5)}.fs-sm{font-size:13px}.fs-lg{font-size:18px}.money{font-family:var(--display);font-variant-numeric:tabular-nums;font-weight:600}.money.pos{color:var(--pos)}.money.neg{color:var(--neg)}.divider{height:1px;background:var(--line);margin:16px 0}.empty{text-align:center;padding:48px 20px;color:var(--ink-3)}.empty .big{font-family:var(--display);font-size:19px;color:var(--ink-2);margin-bottom:6px}.stagger>*{opacity:0;animation:rise .5s cubic-bezier(.2,.7,.3,1) forwards}.stagger>*:nth-child(1){animation-delay:.02s}.stagger>*:nth-child(2){animation-delay:.07s}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.17s}.stagger>*:nth-child(5){animation-delay:.22s}.stagger>*:nth-child(6){animation-delay:.27s}.bar-track{height:8px;border-radius:999px;background:var(--paper-2);overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#3a93b0,var(--teal))}.bar-fill.pos{background:linear-gradient(90deg,#43a06b,var(--pos))}.bar-fill.neg{background:linear-gradient(90deg,#cc424d,var(--neg))}.bar-fill.warn{background:linear-gradient(90deg,#d6a32b,var(--warn))}.toast-wrap{position:fixed;bottom:calc(22px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:90;display:flex;flex-direction:column;gap:8px}.toast{background:var(--ink);color:var(--paper);padding:11px 18px;border-radius:12px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:pop .2s ease}.toast .ic{width:16px;height:16px;color:#7fd1a0}@media (max-width: 900px){.app{grid-template-columns:1fr}.sidebar{display:none}.menu-btn{display:inline-flex}.topbar{padding:12px 16px;flex-wrap:wrap;row-gap:10px}.topbar .page-title{font-size:19px;white-space:nowrap}.topbar-actions{order:3;margin-left:auto;justify-content:flex-end}.topbar-actions .btn.primary{display:none}.topbar-actions:not(:has(.btn:not(.primary))){display:none}.page{padding:18px 16px 96px}.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}.cols-4{grid-template-columns:1fr 1fr}.split,.field-row{grid-template-columns:1fr}.card-head{flex-wrap:wrap}.card-head .right{margin-left:0;width:100%}.toast-wrap{bottom:calc(76px + env(safe-area-inset-bottom))}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:40;background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--line);padding:8px 6px calc(8px + env(safe-area-inset-bottom));justify-content:space-around}.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--ink-3);padding:4px 8px;border-radius:10px}.mobile-nav a .ic{width:20px;height:20px}.mobile-nav a.active{color:var(--accent)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;background:#281a1066;animation:fade .15s}.drawer{position:fixed;top:0;left:0;bottom:0;width:min(88vw,330px);z-index:71;background:var(--surface);border-right:1px solid var(--line);padding:18px 14px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:6px;animation:slide .2s ease;overflow-y:auto}.drawer .nav-item{padding:13px 14px;font-size:15.5px;gap:14px;border-radius:13px;min-height:50px}.drawer .nav-item .ic{width:22px;height:22px}.drawer .nav-item.active{box-shadow:inset 0 0 0 1px #b21f2b29,inset 4px 0 0 var(--accent)}.drawer .nav-group-label{font-size:11px;letter-spacing:.14em;padding:18px 12px 8px}.drawer .brand{padding-bottom:16px}.drawer .brand .word b{font-size:19px}@keyframes slide{0%{transform:translate(-100%)}}}@media (max-width: 680px){.card:has(table.tbl){border:none;box-shadow:none;background:transparent}.card:has(table.tbl)>.table-wrap{overflow:visible}.card:has(table.tbl) .card-head{padding-left:4px;padding-right:4px;border:none}table.tbl thead{display:none}table.tbl,table.tbl tbody,table.tbl tfoot,table.tbl tr,table.tbl td{display:block;width:100%}table.tbl tr{border:1px solid #ececed;border-radius:var(--r-lg);margin-bottom:14px;padding:4px 2px;background:var(--surface);box-shadow:var(--shadow-pop);overflow:hidden}table.tbl tbody tr:hover{background:var(--surface)}table.tbl td{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:7px 18px;border-bottom:none;text-align:right;font-size:14px;font-weight:500;color:var(--ink)}table.tbl tbody td:nth-child(2){padding-top:14px}table.tbl td:last-child{padding-bottom:14px}table.tbl td:before{content:attr(data-label);text-align:left;white-space:nowrap;color:var(--ink-3);font-size:12.5px;font-weight:500;text-transform:none;letter-spacing:0;flex:none}table.tbl td:first-child{background:transparent;border-bottom:1px solid var(--line);border-radius:0;font-size:16.5px;font-weight:800;justify-content:flex-start;padding:16px 18px 13px;color:var(--ink);letter-spacing:-.02em}table.tbl td:first-child:before{content:""}table.tbl tfoot td{background:var(--surface-2)}}@media (max-width: 600px){.overlay{align-items:flex-end;padding:0}.modal,.modal.wide{max-width:100%;width:100%;border-radius:22px 22px 0 0;max-height:92vh;animation:sheet .3s cubic-bezier(.2,.8,.2,1);padding-bottom:env(safe-area-inset-bottom)}.modal:before{content:"";display:block;width:38px;height:5px;border-radius:3px;background:var(--line-strong);margin:9px auto 2px}.modal-head{padding:12px 20px 14px}.modal-foot{padding-bottom:calc(16px + env(safe-area-inset-bottom))}@keyframes sheet{0%{transform:translateY(100%)}}.input,.select,textarea.input{padding:12px 14px;font-size:16px;border-radius:12px}.input-prefix .input{padding-left:40px}.btn{padding:12px 16px;font-size:15px;border-radius:12px}.btn.sm{padding:9px 13px;font-size:13.5px}.btn.icon{padding:10px;min-width:44px;min-height:44px}.seg button{padding:9px 14px}.nav-item:active,.mobile-nav a:active,table.tbl tbody tr:active,.card.row-click:active,.btn:active{opacity:.65}.mobile-nav{padding-top:10px}.mobile-nav a .ic{width:22px;height:22px}.mobile-nav a{font-size:10.5px;gap:4px}}@media (max-width: 480px){.cols-4{grid-template-columns:1fr}.stat .value{font-size:26px}.page{padding:16px 14px 96px}}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 500px at 50% -10%,rgba(178,31,43,.08),transparent 60%),var(--paper)}.login-card{width:100%;max-width:360px;padding:28px 24px calc(24px + env(safe-area-inset-bottom))}.login-err{margin-top:10px;font-size:13px;color:var(--neg);background:var(--neg-soft);padding:8px 12px;border-radius:10px}.splash{min-height:100vh;display:grid;place-items:center;background:var(--paper)}.spinner{width:38px;height:38px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){::view-transition-old(root){animation:vt-out .2s ease both}::view-transition-new(root){animation:vt-in .26s ease both}}@keyframes vt-out{to{opacity:0;transform:translateY(-6px)}}@keyframes vt-in{0%{opacity:0;transform:translateY(8px)}}.fab{display:none}@media (max-width: 900px){.fab{display:inline-flex;align-items:center;gap:8px;position:fixed;right:16px;z-index:45;bottom:calc(80px + env(safe-area-inset-bottom));padding:14px 20px;border-radius:999px;background:linear-gradient(180deg,#c8303d,var(--accent));color:#fff;border:none;font-weight:700;font-size:15px;box-shadow:0 10px 26px -6px #b21f2b80;cursor:pointer;animation:rise .3s ease}.fab .ic{width:20px;height:20px}.fab:active{transform:translateY(1px);opacity:.9}}.fab-export{position:fixed;right:20px;bottom:24px;z-index:46;width:56px;height:56px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#21a85e,#128c4f);color:#fff;border:none;cursor:pointer;box-shadow:0 12px 26px -8px #128c4f8c;transition:transform .08s}.fab-export .ic{width:24px;height:24px}.fab-export:active{transform:translateY(1px);opacity:.92}@media (max-width: 900px){.fab-export{right:16px;bottom:calc(84px + env(safe-area-inset-bottom))}}.btn.wa{color:#128c4f;border-color:#b9e6cd}.btn.wa:hover{background:#e7f6ee;border-color:#21a85e}.skel{background:linear-gradient(90deg,var(--surface-2) 25%,#eef0f3 37%,var(--surface-2) 63%);background-size:400% 100%;border-radius:8px;animation:shimmer 1.4s ease infinite;display:block}@keyframes shimmer{0%{background-position:100% 0}to{background-position:0 0}}@media (prefers-reduced-motion: reduce){.skel{animation:none}}.sel-wrap{position:relative}.sel-wrap.inline{display:inline-block}.sel-wrap.inline .sel-trigger{width:auto;min-width:160px}.sel-trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;cursor:pointer}.sel-trigger .chev{width:16px;height:16px;color:var(--ink-3);flex:none;transition:transform .15s}.sel-trigger[aria-expanded=true] .chev{transform:rotate(90deg)}.sel-trigger .ph{color:var(--ink-3)}.sel-trigger .val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sel-pop{position:absolute;z-index:65;left:0;right:0;margin-top:6px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;max-height:280px;overflow:auto;animation:pop .14s ease}.sel-list{display:flex;flex-direction:column;gap:2px}.sheet-tall{display:flex;flex-direction:column;gap:10px}.sheet-search{flex:none}.sheet-search .search{width:100%;min-width:0}.sel-list.scroll{overflow-y:auto;max-height:56vh}@media (max-width: 600px){.sheet-tall{min-height:52vh}.sel-list.scroll{max-height:64vh}}.sel-opt{display:flex;align-items:center;gap:10px;justify-content:space-between;width:100%;padding:10px 11px;border:none;background:none;border-radius:9px;font:inherit;font-size:14px;color:var(--ink);cursor:pointer;text-align:left}.sel-opt:hover{background:var(--surface-2)}.sel-opt.on{color:var(--accent-ink);font-weight:600;background:var(--accent-soft)}.sel-opt .ic{width:16px;height:16px;color:var(--accent);flex:none}@media (max-width: 600px){.sel-opt{padding:13px 14px;font-size:15px}}.df-trigger{display:inline-flex;align-items:center;gap:8px;cursor:pointer;text-align:left;min-width:150px}.df-trigger.block{width:100%}.df-trigger .ic{width:16px;height:16px;color:var(--ink-3);flex:none}.df-trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.daterange{display:flex;align-items:center;gap:8px;min-width:0}.daterange .df-trigger{flex:1 1 0;min-width:0}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}@media (max-width: 600px){.toolbar>*{width:100%}.toolbar .seg{width:auto}.daterange{width:100%}}.cal{max-width:340px;margin:0 auto}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cal-head .m{font-weight:700;font-size:15px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{text-align:center;font-size:11px;color:var(--ink-3);font-weight:700;padding:4px 0}.cal-day{height:42px;width:100%;border:none;background:none;border-radius:10px;font:inherit;font-size:14px;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center}.cal-day:hover{background:var(--surface-2)}.cal-day.on{background:var(--accent);color:#fff;font-weight:700}.cal-day.today{box-shadow:inset 0 0 0 1.5px var(--accent-soft)}.cal-day.empty{visibility:hidden}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.seg-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;flex-wrap:nowrap;scrollbar-width:none}.seg-scroll::-webkit-scrollbar{display:none}.seg-scroll button{white-space:nowrap}.sell-grid{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}.sell-side{position:sticky;top:18px}.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.prod-tile{display:flex;flex-direction:column;gap:6px;text-align:left;min-height:96px;padding:13px 14px;border-radius:15px;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface);box-shadow:var(--shadow-sm);font:inherit;color:var(--ink);transition:transform .08s ease,box-shadow .15s ease,border-color .15s ease}.prod-tile:hover{border-color:var(--accent-2);box-shadow:var(--shadow)}.prod-tile:active{transform:scale(.97)}.prod-tile.is-out{opacity:.55;cursor:not-allowed}.prod-tile-name{font-weight:600;font-size:14px;line-height:1.3}.sell-cart{background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}.sell-cart .card-head{padding:14px 16px}.sell-lines{padding:6px 12px;display:flex;flex-direction:column;gap:2px;max-height:46vh;overflow-y:auto}.sell-line{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}.sell-line:last-child{border-bottom:none}.qty-step{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border-radius:10px;padding:3px}.qty-step .btn.icon.sm{width:28px;height:28px}.sell-pay{padding:14px 16px;border-top:1px solid var(--line);background:var(--surface-2)}.sell-fab{display:none;position:fixed;left:16px;right:16px;z-index:45;bottom:calc(16px + env(safe-area-inset-bottom));align-items:center;gap:10px;justify-content:center;padding:15px 18px;border:none;border-radius:16px;cursor:pointer;background:var(--accent);color:#fff;font:inherit;font-weight:700;font-size:15px;box-shadow:var(--shadow-lg)}.sell-fab b{margin-left:auto}.sell-sheet{position:fixed;left:0;right:0;bottom:0;z-index:72;background:var(--surface);border-radius:20px 20px 0 0;padding:14px 14px calc(14px + env(safe-area-inset-bottom));box-shadow:var(--shadow-lg);animation:sheetup .22s ease;max-height:88vh;overflow-y:auto}@keyframes sheetup{0%{transform:translateY(100%)}}.receipt-ok{width:min(92vw,340px);text-align:center;z-index:61;animation:okpop .2s ease}.ok-circle{width:64px;height:64px;border-radius:50%;margin:0 auto;display:grid;place-items:center;background:var(--pos);color:#fff}@keyframes okpop{0%{transform:scale(.9);opacity:0}}@media (max-width: 900px){.sell-grid{grid-template-columns:1fr}.sell-side{display:none}.sell-fab{display:flex}}.prod-thumb{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;overflow:hidden;background:var(--surface-2);color:var(--muted);margin-right:10px;vertical-align:middle;flex:0 0 auto}.prod-thumb img{width:100%;height:100%;object-fit:cover}.img-upload{display:flex;align-items:center;gap:12px}.img-drop{display:flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:12px;cursor:pointer;border:1.5px dashed var(--line-strong);background:var(--surface-2);overflow:hidden;text-align:center;padding:6px}.img-drop:hover{border-color:var(--accent)}.img-drop img{width:100%;height:100%;object-fit:cover;border-radius:8px}.ledger-deck{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:14px}.ledger-date{display:flex;align-items:center;gap:4px}.ledger-date-mid{display:flex;align-items:center;gap:10px}.ledger-today{font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--teal);background:var(--teal-soft);border-radius:999px;padding:4px 10px}.ledger-stats{display:flex;gap:10px;flex-wrap:wrap}.lstat{display:flex;flex-direction:column;align-items:flex-end;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:8px 14px;min-width:96px;box-shadow:var(--shadow-sm)}.lstat-n{font-weight:700;font-size:18px;line-height:1.2;font-variant-numeric:tabular-nums}.lstat-l{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.lstat.accent{background:var(--accent-soft);border-color:transparent}.lstat.accent .lstat-n{color:var(--accent-ink)}.lstat.accent .lstat-l{color:var(--accent-ink);opacity:.75}.ledger-card{background:var(--surface);border:1px solid #f1f1f4;border-radius:var(--r-lg);box-shadow:var(--shadow);overflow:hidden}.ledger-wrap{overflow:auto;max-height:calc(100vh - 280px)}table.ledger{border-collapse:separate;border-spacing:0;width:100%;min-width:980px}table.ledger th,table.ledger td{padding:8px 10px;font-size:13px;white-space:nowrap;border-bottom:1px solid var(--line)}table.ledger thead th{position:sticky;background:var(--surface);z-index:3}table.ledger thead .lh-grp th{top:0;padding-top:12px}table.ledger thead .lh-sub th{top:38px;border-bottom:1px solid var(--line-strong)}table.ledger thead th.grp{text-align:center;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2)}table.ledger thead .lh-sub th,table.ledger thead th.num-h{font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);text-align:center}table.ledger thead th.in-h{color:var(--accent)}table.ledger thead th.result-h{color:var(--ink)}table.ledger .sticky-col{position:sticky;left:0;background:var(--surface);z-index:2;border-right:1px solid var(--line);min-width:168px;text-align:left}table.ledger thead .sticky-col{z-index:4}table.ledger td.lname{font-weight:600;font-size:13px}table.ledger td.num{text-align:center;font-variant-numeric:tabular-nums}table.ledger td.quiet{color:var(--ink-3)}table.ledger td.semi{font-weight:500}table.ledger td.neg{color:var(--neg);font-weight:600}table.ledger td.hpp{font-size:12px}table.ledger td.result{font-weight:700;background:var(--surface-2);border-left:1px solid var(--line)}table.ledger td.in-cell{padding:4px 6px}.cell-input{width:60px;padding:7px 4px;text-align:center;font:inherit;font-size:13px;font-variant-numeric:tabular-nums;background:var(--surface);color:var(--ink);border:1px solid var(--line-strong);border-radius:var(--r-sm);box-shadow:var(--shadow-input);transition:border-color .12s,box-shadow .12s}.cell-input::placeholder{color:var(--ink-3);opacity:.5}.cell-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.cell-input::-webkit-inner-spin-button{display:none}table.ledger td:nth-child(3),table.ledger td:nth-child(7),table.ledger td:nth-child(11),table.ledger tr.lh-grp th:nth-child(3),table.ledger tr.lh-grp th:nth-child(4),table.ledger tr.lh-grp th:nth-child(5),table.ledger tr.lh-grp th:nth-child(6),table.ledger tr.lh-sub th:nth-child(1),table.ledger tr.lh-sub th:nth-child(5),table.ledger tr.lh-sub th:nth-child(9){border-left:1px solid var(--line)}table.ledger tbody tr:hover td{background:var(--surface-2)}table.ledger tfoot td{position:sticky;bottom:0;background:var(--surface-2);font-weight:700;font-size:12.5px;text-align:center;font-variant-numeric:tabular-nums;border-bottom:none;border-top:2px solid var(--line-strong);padding:10px}table.ledger tfoot td.sticky-col{background:var(--surface-2);text-align:left}table.ledger tfoot td.result{background:var(--accent-soft);color:var(--accent-ink);border-left:none}.ledger-hint{margin-top:10px;font-size:12px;color:var(--ink-3);line-height:1.6}.hint-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--accent);margin:0 2px}.seg.scroll-x{overflow-x:auto;white-space:nowrap;max-width:100%;scrollbar-width:none}.seg.scroll-x::-webkit-scrollbar{display:none}.fin-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:12px 0}.sheet-zone{display:flex;flex-direction:column;align-items:center}.sheet-actions{display:flex;gap:8px;justify-content:flex-end;width:100%;max-width:760px;margin-bottom:10px}.sheet{width:100%;max-width:760px;background:var(--surface);border:1px solid #f1f1f4;border-radius:var(--r-lg);box-shadow:var(--shadow);padding:clamp(16px,3vw,32px) clamp(14px,4vw,40px) 22px}.sheet.wide{max-width:940px}.sheet-zone:has(.sheet.wide) .sheet-actions{max-width:940px}.letterhead{padding:4px 0 14px;border-bottom:2px solid var(--ink);margin-bottom:6px}.lh-top{display:flex;align-items:center;gap:14px}.lh-logo{height:50px;width:auto;flex:none}.lh-org{text-align:left;min-width:0}.lh-co{font-size:15px;font-weight:800;letter-spacing:.03em;color:var(--ink)}.lh-addr{font-size:11.5px;color:var(--ink-3);margin-top:2px}.lh-top .badge{margin-left:auto;flex:none}.lh-doc{text-align:center;margin-top:14px}.lh-title{font-size:19px;font-weight:700;letter-spacing:-.01em;margin:0}.lh-period{font-size:12.5px;color:var(--ink-3);margin-top:3px}@media (max-width: 480px){.lh-logo{height:40px}.lh-co{font-size:13.5px}}table.stmt{width:100%;border-collapse:collapse}table.stmt td{padding:8px 4px;font-size:13.5px}table.stmt td.ind{padding-left:24px}table.stmt td.amt,table.stmt-grid td.amt{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;font-size:13.5px}tr.srow-sec td{padding:16px 0 6px}tr.srow-sec span{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}tr.srow-total td{font-weight:600;border-top:1px solid var(--line-strong)}tr.srow-grand td{font-weight:700;font-size:14px;border-top:1px solid var(--ink)}tr.srow-grand td.amt{border-bottom:3px double var(--ink);padding-bottom:3px}tr.srow-grand+tr td{padding-top:12px}table.stmt-grid{width:100%;border-collapse:collapse;margin:6px 0 10px}table.stmt-grid th{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:left;padding:7px 6px;border-bottom:1px solid var(--line-strong)}table.stmt-grid th.amt-h{text-align:right}table.stmt-grid td{padding:7px 6px;font-size:13px;border-bottom:1px solid var(--line)}table.stmt-grid td.ind{padding-left:22px}table.stmt-grid td.code{font-variant-numeric:tabular-nums;color:var(--ink-3);font-size:12px}table.stmt-grid td.je-desc{color:var(--ink-2);max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}table.stmt-grid tr.je-first td{border-top:1px solid var(--line-strong)}table.stmt-grid tr.srow-total td,table.stmt-grid tr.srow-grand td{border-bottom:none}table.stmt-grid tr.srow-grand td.amt{border-bottom:3px double var(--ink)}.notes h4{font-size:14px;font-weight:700;margin:20px 0 8px}.notes ol{margin:0 0 8px 22px;font-size:12.5px;color:var(--ink-2);line-height:1.75}.notes p{font-size:12.5px;color:var(--ink-3);margin:0 0 8px}.btn.tx-pick{justify-content:flex-start;gap:10px;padding:12px 14px}.tx-pick-label{font-weight:600}.tx-pick-hint{margin-left:auto;font-size:11px;color:var(--ink-3)}@media print{body *{visibility:hidden}.print-area,.print-area *{visibility:visible}.print-area{position:absolute;left:0;top:0;width:100%;max-width:none;border:none;box-shadow:none;border-radius:0;padding:10mm 12mm}}.ledger-pdf{flex:none;margin-left:6px}.rekap-print{display:none}@media print{.rekap-print{display:block}@page{size:A4 landscape;margin:0}}.rekap-print .rp-head{text-align:center;margin-bottom:8mm}.rekap-print .rp-head h1{font-size:15pt;font-weight:800;letter-spacing:.04em;margin:0}.rekap-print .rp-head h2{font-size:11pt;font-weight:700;margin:2mm 0 0}.rekap-print .rp-head p{font-size:10pt;color:#444;margin:1mm 0 0}.rekap-print .rp-table{width:100%;border-collapse:collapse;font-size:8.5pt}.rekap-print .rp-table th,.rekap-print .rp-table td{border:.4pt solid #999;padding:1.4mm 1.8mm;text-align:right}.rekap-print .rp-table th{background:#f0f0f0;font-weight:700;text-align:center}.rekap-print .rp-table .l{text-align:left}.rekap-print .rp-table .r{text-align:right}.rekap-print .rp-table .neg{color:#c0261c;font-weight:700}.rekap-print .rp-table tfoot td{font-weight:800;background:#f7f7f7}.rekap-print .rp-foot{margin-top:6mm;font-size:8pt;color:#777;text-align:center}.info{position:relative;display:inline-flex;vertical-align:middle;margin-left:4px}.info-btn{display:inline-grid;place-items:center;width:18px;height:18px;padding:0;border:none;background:none;cursor:pointer;color:var(--ink-3);border-radius:50%;transition:color .12s,background .12s}.info-btn:hover{color:var(--accent);background:var(--accent-soft)}.info-pop{position:absolute;z-index:60;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);width:max-content;max-width:248px;padding:10px 12px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:400;line-height:1.5;letter-spacing:0;text-transform:none;text-align:left;white-space:normal;border-radius:10px;box-shadow:var(--shadow-pop);pointer-events:none}.info-pop:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--ink)}@media (max-width: 560px){.info-pop{max-width:220px}}.fin-tabs-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:4px}.fin-tabs-row .seg{flex:1;min-width:0;margin-bottom:0}.fin-adv-toggle{white-space:nowrap;flex:none}.onboard{background:linear-gradient(135deg,#fff,var(--accent-soft) 180%);border-color:var(--accent-soft)}.onboard-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}.onboard-step{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);transition:border-color .12s,box-shadow .12s,transform .08s}.onboard-step:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.onboard-step:active{transform:scale(.99)}.onboard-num{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-ink);font-weight:700;font-size:14px}.onboard-step.done .onboard-num{background:var(--pos-soft);color:var(--pos)}.onboard-body{display:flex;flex-direction:column;min-width:0;flex:1}.onboard-title{font-weight:600;font-size:13.5px}.onboard-step.done .onboard-title{color:var(--ink-3);text-decoration:line-through}.onboard-desc{font-size:11.5px;color:var(--ink-3)}.onboard-go{color:var(--ink-3);flex:none}
