:root{--primary: #0891B2;--primary-deep: #075E73;--primary-soft: color-mix(in srgb, var(--primary) 12%, var(--card));--accent: #FF7A55;--accent-soft: color-mix(in srgb, var(--accent) 17%, var(--card));--ink: #0F1A1F;--ink-2: #3A4A52;--ink-3: #6B7A82;--ink-4: #A5B2B8;--bg: #F4F1EC;--card: #FFFFFF;--line: #E7E2DA;--line-2: #F1ECE4;--ok: #1F8A5B;--warn: #D97706;--danger: #C2410C;--rail: #0C2B33}:root,.card,.hero-cash,.sheet,.toast{transition:background-color .4s ease,color .4s ease,border-color .4s ease}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--ink);font-family:Plus Jakarta Sans,ui-sans-serif,system-ui,sans-serif;font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow:hidden}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}button{font:inherit;cursor:pointer}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#d7d0c5;border-radius:6px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:#c4bcae;background-clip:padding-box}#root{height:100%}.register{height:100%;display:grid;grid-template-columns:76px minmax(0,1fr)}.rail{background:var(--rail);display:flex;flex-direction:column;align-items:center;padding:16px 0 14px;gap:6px}.rail-mark{width:44px;height:44px;border-radius:13px;background:var(--primary);display:grid;place-items:center;box-shadow:inset 0 0 0 1px #ffffff24,0 6px 18px #0891b266;margin-bottom:14px}.rail-mark svg{width:24px;height:24px}.rail-btn{width:56px;height:54px;border-radius:14px;border:0;background:transparent;color:#ffffff80;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;position:relative;transition:all .16s}.rail-btn svg{width:21px;height:21px}.rail-btn:hover{color:#fff;background:#ffffff12}.rail-btn.active{color:#fff;background:#ffffff1f}.rail-btn.active:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:var(--accent)}.rail-label{font-size:9px;letter-spacing:.02em;line-height:1;color:#ffffff73}.rail-btn.active .rail-label{color:#ffffffd9}.rail-spacer{flex:1}.rail-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#ffb89d,#ff7a55);color:#fff;font-weight:700;font-size:13px;display:grid;place-items:center;box-shadow:0 0 0 2px #ffffff1f;margin-top:4px}.screen{display:flex;flex-direction:column;min-width:0;min-height:0}.screen-top{padding:18px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-bottom:1px solid var(--line-2);flex-wrap:wrap}.screen-title h1{margin:0;font-size:22px;font-weight:800;letter-spacing:-.02em}.screen-title p{margin:4px 0 0;font-size:13px;color:var(--ink-3)}.screen-scroll{flex:1;overflow:auto;padding:20px 28px 48px}.owner-chip{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;color:var(--primary-deep);background:var(--primary-soft);padding:9px 14px;border-radius:11px}.owner-chip svg{width:16px;height:16px}.sect-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);margin:26px 2px 12px}.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.stat-l{font-size:11.5px;color:var(--ink-3);font-weight:600}.stat-v{font-size:22px;font-weight:800;letter-spacing:-.01em}.stat.warn{background:var(--accent-soft);border-color:#ffd3c4}.stat.warn .stat-v{color:var(--accent)}.empty-state{text-align:center;padding:50px 20px;color:var(--ink-3)}.empty-state svg{width:38px;height:38px;opacity:.4;margin-bottom:10px}.empty-mini{text-align:center;padding:22px 12px;color:var(--ink-4);font-size:12.5px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;min-width:0}.card-h{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.card-h>div:first-child{flex:1;min-width:0}.card-h b{font-size:14.5px;font-weight:800;letter-spacing:-.01em;display:block}.card-h span{font-size:11.5px;color:var(--ink-3);display:block;margin-top:2px}.card-total{font-size:16px;font-weight:800}.card-total.in{color:var(--ok)}.card-total.out{color:var(--accent)}.legend{display:flex;gap:14px;flex-wrap:wrap}.legend span{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--ink-3)}.legend i{width:11px;height:11px;border-radius:3px}.dash-row{display:grid;gap:16px;margin-bottom:16px;align-items:start}.dash-row.two-one{grid-template-columns:1.85fr 1fr}.dash-row.two{grid-template-columns:1fr 1fr}.dash-row.three{grid-template-columns:repeat(3,1fr)}.dash-top{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;margin-bottom:16px}.hero-cash{border-radius:22px;padding:22px 24px;color:#fff;position:relative;overflow:hidden;background:radial-gradient(130% 150% at 100% 0%,#ffffff2e,#fff0 45%),linear-gradient(135deg,var(--primary) 0%,var(--primary-deep) 100%);box-shadow:0 22px 44px -18px #0891b28c;display:flex;flex-direction:column;justify-content:space-between;gap:18px}.hero-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.hero-l{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;opacity:.92;white-space:nowrap}.hero-l svg{width:17px;height:17px}.hero-spark{opacity:.9}.hero-v{font-size:38px;font-weight:800;letter-spacing:-.02em;line-height:1}.hero-foot{display:flex;gap:10px;flex-wrap:wrap}.hero-pill{display:flex;align-items:center;gap:9px;background:#ffffff21;border:1px solid rgba(255,255,255,.16);border-radius:13px;padding:9px 13px;flex:1;min-width:0}.hero-pill svg{width:16px;height:16px;flex:none;opacity:.9}.hero-pill b{display:block;font-size:14px;font-weight:800;white-space:nowrap}.hero-pill span{display:block;font-size:10px;opacity:.8}.hero-pill.in svg{color:#9debd6}.hero-pill.out svg{color:#ffc9b4}.kpi-col{display:grid;grid-template-rows:repeat(3,1fr);gap:12px}.kpi{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:13px 16px;display:flex;flex-direction:column;gap:4px;justify-content:center}.kpi-l{font-size:11.5px;color:var(--ink-3);font-weight:600}.kpi-v{font-size:24px;font-weight:800;letter-spacing:-.01em;line-height:1.05}.kpi-foot{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-4);margin-top:2px}.kpi-spark{line-height:0}.delta{display:inline-flex;align-items:center;gap:2px;font-size:11px;font-weight:800;padding:2px 7px 2px 4px;border-radius:7px}.delta svg{width:12px;height:12px}.delta.up{color:var(--ok);background:#1f8a5b1a}.delta.down{color:var(--danger);background:#c2410c1a}.chart-wrap{width:100%}.chart-svg{width:100%;display:block}.grid-line{stroke:var(--line-2);stroke-width:1;vector-effect:non-scaling-stroke}.axis-x{fill:var(--ink-4);font-size:11px;font-family:JetBrains Mono,monospace}.donut-box{position:relative;flex:none;display:grid;place-items:center}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}.donut-center b{font-size:16px;font-weight:800;letter-spacing:-.01em}.donut-center span{font-size:9.5px;color:var(--ink-3);font-weight:600}.donut-layout{display:flex;align-items:center;gap:18px}.donut-legend{flex:1;display:flex;flex-direction:column;gap:9px;min-width:0}.dl-row{display:flex;align-items:center;gap:9px;font-size:12px}.dl-row i{width:10px;height:10px;border-radius:3px;flex:none}.dl-lab{flex:1;color:var(--ink-2);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dl-val{font-weight:700;color:var(--ink-3)}.hbars{display:flex;flex-direction:column;gap:11px}.hbar-row{display:grid;grid-template-columns:minmax(0,1fr) 1.3fr auto;align-items:center;gap:12px}.hbar-lab{font-size:12.5px;font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hbar-track{height:9px;border-radius:99px;background:var(--line-2);overflow:hidden}.hbar-track i{display:block;height:100%;border-radius:99px;transition:width .5s cubic-bezier(.3,.9,.3,1)}.hbar-val{font-size:12px;font-weight:800;white-space:nowrap}.susut-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.susut-v{font-size:26px;font-weight:800;letter-spacing:-.01em}.susut-v small{font-size:13px;color:var(--ink-3);font-weight:600}.susut-rp{font-size:12px;color:var(--accent);font-weight:700;margin-top:2px}.susut-list{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--line-2);padding-top:12px}.susut-row{display:grid;grid-template-columns:30px 1fr auto;align-items:center;gap:10px}.susut-nm{font-size:12.5px;font-weight:600;color:var(--ink-2)}.susut-kg{font-size:12px;font-weight:700;color:var(--ink-3)}.mini-code{width:30px;height:26px;border-radius:8px;background:var(--primary-soft);color:var(--primary-deep);display:grid;place-items:center;font-family:JetBrains Mono,monospace;font-weight:700;font-size:10.5px}.kasir-list{display:flex;flex-direction:column;gap:16px}.kasir-meta{display:flex;align-items:center;gap:11px;margin-bottom:8px}.kasir-av{width:36px;height:36px;border-radius:11px;color:#fff;font-size:12px;font-weight:800;display:grid;place-items:center;flex:none}.kasir-nm{font-size:13px;font-weight:700}.kasir-sub{font-size:10.5px;color:var(--ink-3)}.kasir-meta>div:nth-child(2){flex:1;min-width:0}.kasir-omz{font-size:13.5px;font-weight:800}.kasir-track{height:8px;border-radius:99px;background:var(--line-2);position:relative;overflow:visible}.kasir-track i{display:block;height:100%;border-radius:99px;transition:width .5s}.kasir-track b{position:absolute;top:-3px;width:2px;height:14px;background:var(--ink-3);border-radius:2px;transform:translate(-1px)}.kasir-pct{font-size:10.5px;font-weight:700;margin-top:6px}.kasir-pct.hit{color:var(--ok)}.kasir-pct.miss{color:var(--ink-3)}.tempo-list{display:flex;flex-direction:column}.tempo-row{display:grid;grid-template-columns:minmax(0,1.3fr) auto auto;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-2)}.tempo-row:last-child{border-bottom:0}.tempo-party{font-size:13px;font-weight:700;min-width:0}.tempo-party span{display:block;font-size:10.5px;color:var(--ink-3);font-weight:500;margin-top:1px}.tempo-due{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--ink-3);white-space:nowrap}.tempo-due svg{width:13px;height:13px}.tempo-due.over{color:var(--danger)}.tempo-amt{font-size:13.5px;font-weight:800;text-align:right}.rpt-actions{display:flex;gap:9px}.btn-ghost,.btn-solid{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:11px;font-size:12.5px;font-weight:700}.btn-ghost{border:1px solid var(--line);background:var(--card);color:var(--ink-2)}.btn-ghost:hover{border-color:var(--primary);color:var(--primary-deep)}.btn-solid{border:0;background:var(--ink);color:#fff}.btn-solid:hover{filter:brightness(1.12)}.btn-ghost svg,.btn-solid svg{width:15px;height:15px}.period-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}.period-tabs{display:flex;gap:4px;padding:4px;background:var(--card);border:1px solid var(--line);border-radius:12px}.period-tab{border:0;background:transparent;padding:8px 15px;border-radius:9px;font-size:12.5px;font-weight:700;color:var(--ink-3)}.period-tab:hover{color:var(--ink)}.period-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #0891b247}.period-custom{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:7px 12px;font-size:12.5px;color:var(--ink-3)}.period-custom svg{width:15px;height:15px}.period-custom input{border:0;background:transparent;font:inherit;font-size:12.5px;font-weight:600;color:var(--ink);outline:0}.period-label{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--ink-2)}.period-label svg{width:15px;height:15px;color:var(--primary)}.rpt-side{display:flex;flex-direction:column;gap:16px}.statement{display:flex;flex-direction:column}.statement.tight .st-row{padding:7px 0}.st-sect{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);margin:12px 0 4px}.st-sect:first-child{margin-top:0}.st-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:8px 0;font-size:13px}.st-lab{color:var(--ink-2);display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.st-lab em{font-style:normal;font-size:10.5px;color:var(--ink-4);font-weight:600}.st-val{font-weight:700;white-space:nowrap}.st-val.neg{color:var(--danger)}.st-row.strong{font-weight:800}.st-row.strong .st-lab{color:var(--ink);font-weight:800}.st-row.strong .st-val{font-size:15px}.st-val.acc{color:var(--primary-deep)}.st-divider{height:1px;background:var(--line);margin:4px 0}.hpp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center}.hpp-cell{display:flex;flex-direction:column;gap:3px}.hpp-cell span{font-size:11px;color:var(--ink-3);font-weight:600}.hpp-cell b{font-size:17px;font-weight:800;letter-spacing:-.01em}.hpp-cell.ring{grid-row:span 2;grid-column:2;place-items:center;display:grid}.recap-divider{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);margin:16px 0 11px;padding-top:14px;border-top:1px solid var(--line-2)}.rpt-footnote{font-size:11px;color:var(--ink-4);text-align:center;margin-top:20px}.ledger-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px;flex-wrap:wrap}.filter-chips{display:flex;gap:7px;flex-wrap:wrap;align-items:center;flex:1;min-width:0}.chip-f{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:9px;border:1px solid var(--line);background:var(--card);font-size:12px;font-weight:600;color:var(--ink-2)}.chip-f:hover{border-color:var(--ink-4)}.chip-f.active{background:var(--ink);color:#fff;border-color:var(--ink)}.chip-f.cat i{width:9px;height:9px;border-radius:3px}.chip-sep{width:1px;height:22px;background:var(--line);margin:0 3px}.search-box{display:flex;align-items:center;gap:9px;padding:9px 14px;min-width:230px;background:var(--card);border:1px solid var(--line);border-radius:12px}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.search-box svg{width:16px;height:16px;color:var(--ink-3);flex:none}.search-box input{flex:1;border:0;outline:0;background:transparent;font:inherit;font-size:13px;min-width:0}.ledger{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden}.led-head,.led-row{display:grid;grid-template-columns:74px minmax(0,1.7fr) minmax(0,1.4fr) 120px 150px 64px;align-items:center;gap:14px;padding:12px 18px}.led-head{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);font-weight:700;background:var(--bg);border-bottom:1px solid var(--line)}.led-head .ra{text-align:right}.led-row{border-bottom:1px solid var(--line-2);cursor:pointer;transition:background .12s}.led-row:last-child{border-bottom:0}.led-row:hover{background:var(--bg)}.led-row.tempo{background:#d977060a}.led-date b{font-size:12.5px;font-weight:700;display:block}.led-date span{font-size:10px;color:var(--ink-4)}.led-cat{display:flex;align-items:center;gap:11px;min-width:0}.led-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}.led-ic svg{width:17px;height:17px}.led-cat-tx{min-width:0}.led-cat-nm{font-size:13px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.led-note{font-size:10.5px;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.led-party{font-size:12.5px;font-weight:600;color:var(--ink-2);min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:7px}.led-auto{font-size:8.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--primary-deep);background:var(--primary-soft);padding:2px 6px;border-radius:5px;flex:none}.led-method{display:flex;flex-direction:column;gap:3px;align-items:flex-start}.m-pill{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:7px;background:var(--line-2);color:var(--ink-2)}.m-pill.tempo{background:#d9770624;color:var(--warn)}.m-due{font-size:9.5px;font-weight:700;color:var(--ink-4)}.m-due.over{color:var(--danger)}.led-amt{font-size:14px;font-weight:800;text-align:right}.led-amt.in{color:var(--ok)}.led-amt.out{color:var(--accent)}.led-act{display:flex;gap:4px;justify-content:flex-end}.led-edit,.led-trash{width:28px;height:28px;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--ink-4);display:grid;place-items:center}.led-row:hover .led-edit,.led-row:hover .led-trash{border-color:var(--line)}.led-edit svg,.led-trash svg{width:15px;height:15px}.led-edit:hover{color:var(--primary-deep);border-color:var(--primary)}.led-trash:hover{color:var(--danger);border-color:var(--danger)}.load-more{width:100%;margin-top:12px;padding:12px;border:1px dashed var(--line);border-radius:12px;background:var(--card);color:var(--ink-3);font-size:12.5px;font-weight:700}.load-more:hover{border-color:var(--primary);color:var(--primary-deep)}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0c2b336b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:24px;animation:fade .18s ease}@keyframes fade{0%{opacity:0}}.sheet{width:480px;max-width:100%;max-height:92vh;overflow:hidden;background:var(--card);border-radius:24px;box-shadow:0 30px 80px #00000059;display:flex;flex-direction:column;animation:pop .24s cubic-bezier(.2,.9,.3,1.2)}.sheet-wide{width:620px}.sheet-sm{width:400px}@keyframes pop{0%{opacity:0;transform:translateY(14px) scale(.97)}}.sheet-head{padding:20px 22px;border-bottom:1px solid var(--line-2);display:flex;align-items:center;justify-content:space-between;gap:12px}.sheet-head h2{margin:0;font-size:18px;font-weight:800;letter-spacing:-.01em}.sheet-head p{margin:3px 0 0;font-size:12px;color:var(--ink-3)}.sheet-x{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--ink-2);display:grid;place-items:center;flex:none}.sheet-x svg{width:17px;height:17px}.sheet-x:hover{background:var(--bg)}.sheet-body{padding:20px 22px;overflow-y:auto}.sheet-foot{padding:16px 22px;border-top:1px solid var(--line-2);display:flex;gap:10px;justify-content:flex-end}.btn-pri{padding:13px 20px;border:0;border-radius:13px;background:var(--primary);color:#fff;font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 6px 18px #0891b24d}.btn-pri:hover:not(:disabled){filter:brightness(1.06)}.btn-pri:disabled{background:var(--line);color:var(--ink-4);box-shadow:none}.btn-pri svg{width:18px;height:18px}.btn-pri.sm,.btn-sec.sm{padding:9px 14px;font-size:12.5px;border-radius:10px;box-shadow:none}.btn-sec{padding:13px 18px;border:1px solid var(--line);border-radius:13px;background:var(--card);color:var(--ink-2);font-size:14px;font-weight:600}.btn-sec:hover{background:var(--bg)}.btn-danger{padding:13px 18px;border:1px solid #F0C8B5;border-radius:13px;background:#c2410c0f;color:var(--danger);font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:7px;margin-right:auto}.btn-danger:hover{background:#c2410c1f}.btn-danger:disabled{opacity:.45;cursor:not-allowed}.btn-danger svg{width:16px;height:16px}.seg{display:flex;gap:5px;padding:5px;background:var(--bg);border-radius:13px}.type-seg{margin-bottom:16px}.seg-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px;border:0;border-radius:9px;background:transparent;font-size:13px;font-weight:700;color:var(--ink-3)}.seg-btn svg{width:16px;height:16px}.seg-btn.sm{padding:9px 6px;font-size:12px}.seg-btn.on{background:var(--card);box-shadow:0 1px 3px #0f1a1f1f}.seg-btn.in.on{color:var(--ok)}.seg-btn.out.on{color:var(--accent)}.seg-btn.sm.on{color:var(--primary-deep)}.seg-btn:disabled{opacity:.4}.fld{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.fld-l{font-size:12px;font-weight:700;color:var(--ink-2)}.fld-l em{font-style:normal;font-weight:500;color:var(--ink-4)}.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.txt{border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font:inherit;font-size:14px;outline:0;background:var(--bg);width:100%}.txt:focus{border-color:var(--primary);background:var(--card)}.money-in{display:flex;align-items:center;gap:8px;border:1.5px solid var(--line);border-radius:12px;padding:11px 14px;background:var(--bg)}.money-in:focus-within{border-color:var(--primary);background:var(--card)}.money-in>span{font-size:14px;font-weight:700;color:var(--ink-3)}.money-in input{flex:1;min-width:0;border:0;outline:0;background:transparent;font:inherit;font-weight:800;font-size:22px;letter-spacing:-.01em}.cat-pick{display:flex;flex-wrap:wrap;gap:7px}.cat-opt{display:inline-flex;align-items:center;gap:8px;padding:8px 12px 8px 8px;border-radius:11px;border:1.5px solid var(--line);background:var(--card);font-size:12.5px;font-weight:600;color:var(--ink-2)}.cat-opt:hover{border-color:var(--ink-4)}.cat-dot{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;color:#fff;flex:none}.cat-dot svg{width:14px;height:14px}.tempo-toggle{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 14px;border:1.5px solid var(--line);border-radius:13px;background:var(--card);margin-bottom:14px}.tempo-toggle.on{border-color:var(--warn);background:#d977060f}.tt-box{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line);flex:none;display:grid;place-items:center;background:var(--card)}.tt-box svg{width:14px;height:14px;color:#fff}.tempo-toggle.on .tt-box{background:var(--warn);border-color:var(--warn)}.tt-tx{flex:1;line-height:1.25}.tt-tx b{font-size:13px;font-weight:700}.tt-tx span{display:block;font-size:11px;color:var(--ink-3)}.tt-due{border:1px solid var(--line);border-radius:9px;padding:7px 9px;font:inherit;font-size:12px;font-weight:600;background:var(--card);outline:0;flex:none}.confirm{text-align:center;padding:26px 22px 8px}.confirm-ic{width:56px;height:56px;border-radius:50%;background:#c2410c1a;color:var(--danger);display:grid;place-items:center;margin:0 auto 14px}.confirm-ic svg{width:26px;height:26px}.confirm h3{margin:0 0 6px;font-size:17px;font-weight:800}.confirm p{margin:0;font-size:12.5px;color:var(--ink-3)}.cm-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.cm-col-h{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);margin-bottom:10px}.cm-row{display:grid;grid-template-columns:26px 1fr auto auto 28px;align-items:center;gap:8px;margin-bottom:7px}.cm-color{position:relative;width:26px;height:26px;cursor:pointer}.cm-color input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.cm-color i{display:block;width:22px;height:22px;border-radius:7px;box-shadow:inset 0 0 0 1px #00000014}.cm-name{border:1.5px solid transparent;border-radius:8px;padding:6px 9px;font:inherit;font-size:12.5px;font-weight:600;background:var(--bg);outline:0;min-width:0}.cm-name:focus{border-color:var(--primary);background:var(--card)}.cm-auto{font-size:8.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--primary-deep);background:var(--primary-soft);padding:2px 6px;border-radius:5px}.cm-used{font-size:10.5px;font-weight:700;color:var(--ink-4);min-width:18px;text-align:right}.cm-del{width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:var(--card);color:var(--ink-4);display:grid;place-items:center}.cm-del svg{width:14px;height:14px}.cm-del:hover:not(:disabled){color:var(--danger);border-color:var(--danger)}.cm-del:disabled{opacity:.3;cursor:not-allowed}.cm-add{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:8px 12px;border-radius:9px;border:1px dashed var(--line);background:transparent;font-size:12px;font-weight:700;color:var(--primary-deep)}.cm-add:hover{border-color:var(--primary);background:var(--primary-soft)}.cm-add svg{width:14px;height:14px}.cm-add-form{margin-top:8px;padding:11px;border:1px solid var(--line);border-radius:12px;background:var(--bg)}.cm-swatches{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px}.cm-sw{width:22px;height:22px;border-radius:7px;border:2px solid transparent}.cm-sw.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--card) inset}.cm-add-row{display:flex;gap:7px}.cm-add-row .cm-name{flex:1;background:var(--card);border-color:var(--line)}.cm-auto.sys{color:var(--ink-3);background:var(--line-2)}.btn-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;margin-left:2px;border-radius:99px;background:var(--warn);color:#fff;font-size:10.5px;font-weight:800}.rec-banner{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:13px 16px;margin-bottom:16px;border:1px solid #F0D5A8;border-radius:14px;background:#d9770614}.rec-banner-tx{display:flex;align-items:center;gap:11px;min-width:0;flex:1}.rec-banner-tx>div{min-width:0;flex:1}.rec-banner .rb-ic{width:34px;height:34px;border-radius:10px;background:#d9770629;color:var(--warn);display:grid;place-items:center;flex:none}.rec-banner .rb-ic svg{width:18px;height:18px}.rec-banner b{font-size:13.5px;font-weight:800;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-banner-tx span{font-size:11.5px;color:var(--ink-3);display:block;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-banner-act{display:flex;gap:8px;flex:none}.rb-ghost,.rb-solid{padding:9px 15px;border-radius:10px;font-size:12.5px;font-weight:700}.rb-ghost{border:1px solid var(--line);background:var(--card);color:var(--ink-2)}.rb-ghost:hover{border-color:var(--warn);color:var(--warn)}.rb-solid{border:0;background:var(--warn);color:#fff}.rb-solid:hover{filter:brightness(1.08)}.rec-postall{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;margin-bottom:14px;border-radius:12px;background:#d9770614;border:1px solid #F0D5A8}.rec-postall span{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--warn)}.rec-postall svg{width:16px;height:16px}.rec-postall button{border:0;background:var(--warn);color:#fff;font-size:12.5px;font-weight:700;padding:8px 14px;border-radius:9px}.rec-list{display:flex;flex-direction:column;gap:9px}.rec-row{display:grid;grid-template-columns:38px 34px minmax(0,1fr) auto auto auto;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:13px;background:var(--card)}.rec-row.due{border-color:#f0d5a8;background:#d977060d}.rec-row.off{opacity:.55}.rec-tog{width:38px;height:22px;border-radius:99px;border:0;background:var(--line);position:relative;flex:none;padding:0;transition:background .16s}.rec-tog span{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .16s}.rec-tog.on{background:var(--ok)}.rec-tog.on span{transform:translate(16px)}.rec-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}.rec-ic svg{width:17px;height:17px}.rec-meta{min-width:0}.rec-nm{font-size:13px;font-weight:700;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rec-sub{font-size:11px;color:var(--ink-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.rec-amt{font-size:13.5px;font-weight:800;white-space:nowrap}.rec-due{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;color:var(--ink-3);white-space:nowrap}.rec-due svg{width:13px;height:13px}.rec-due.over{color:var(--warn)}.rec-act{display:flex;align-items:center;gap:5px}.rec-post{display:inline-flex;align-items:center;gap:5px;padding:7px 11px;border:0;border-radius:9px;background:var(--warn);color:#fff;font-size:11.5px;font-weight:700}.rec-post svg{width:14px;height:14px}.rec-form{display:flex;flex-direction:column}.rec-form .fld{margin-bottom:13px}.rec-form-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}select.txt{-moz-appearance:none;appearance:none;-webkit-appearance:none}.del-reason{text-align:left;margin-top:16px;padding-top:14px;border-top:1px solid var(--line-2)}.del-reason-l{font-size:12px;font-weight:700;color:var(--ink-2);margin-bottom:9px}.del-reason-l em{font-style:normal;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--danger);margin-left:5px}.del-reasons{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:9px}.del-chip{padding:8px 13px;border-radius:9px;border:1.5px solid var(--line);background:var(--card);font-size:12.5px;font-weight:600;color:var(--ink-2)}.del-chip:hover{border-color:var(--ink-4)}.del-chip.on{border-color:var(--danger);background:#c2410c14;color:var(--danger)}.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%);z-index:80;background:var(--ink);color:#fff;padding:11px 18px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 12px 30px #0000004d;display:flex;align-items:center;gap:9px;animation:toastin .25s cubic-bezier(.2,.9,.3,1.2)}.toast svg{width:17px;height:17px;color:#7df0b8}@keyframes toastin{0%{opacity:0;transform:translate(-50%,12px)}}@media(max-width:1180px){.dash-row.two-one,.dash-top,.dash-row.three{grid-template-columns:1fr}.kpi-col{grid-template-rows:none;grid-template-columns:repeat(3,1fr)}}@media(max-width:860px){.register{grid-template-columns:64px minmax(0,1fr)}.screen-top,.screen-scroll{padding-left:16px;padding-right:16px}.stat-strip{grid-template-columns:repeat(2,1fr)}.dash-row.two,.kpi-col{grid-template-columns:1fr}.led-head{display:none}.led-row{grid-template-columns:1fr auto;gap:6px 12px;padding:14px 16px}.led-row .led-cat{grid-column:1;order:1}.led-row .led-amt{grid-column:2;order:1}.led-row .led-date{grid-column:1;order:0}.led-row .led-party{grid-column:1 / -1;order:2}.led-row .led-method{grid-column:1;order:3}.led-row .led-act{grid-column:2;order:3}}:root[data-density=lega] body{font-size:15px}:root[data-density=lega] .card{padding:22px}:root[data-density=lega] .screen-scroll{padding:24px 32px 52px}:root[data-density=lega] .led-head,:root[data-density=lega] .led-row{padding:15px 20px}:root[data-density=padat] body{font-size:13px}:root[data-density=padat] .card{padding:14px}:root[data-density=padat] .screen-scroll{padding:16px 20px 36px}:root[data-density=padat] .led-head,:root[data-density=padat] .led-row{padding:9px 14px}:root[data-density=padat] .stat{padding:11px 13px}:root[data-density=padat] .dash-row,:root[data-density=padat] .dash-top{gap:12px;margin-bottom:12px}@media print{@page{size:A4 portrait;margin:14mm}html,body{background:#fff;height:auto;overflow:visible}*{-webkit-print-color-adjust:exact;print-color-adjust:exact}.rail,.twk-panel,.toast,.no-print,.led-act{display:none!important}.register{display:block}.screen-scroll{overflow:visible;padding:0}.screen-top{padding:0 0 12px}.card,.stat,.dash-row,.dash-top{break-inside:avoid;box-shadow:none}.dash-row.two-one,.dash-row.two{grid-template-columns:1fr 1fr}}.auth-wrap{height:100%;display:grid;place-items:center;padding:24px}.auth-card{width:360px;max-width:100%;background:var(--card);border:1px solid var(--line);border-radius:24px;box-shadow:0 30px 80px -30px #0c2b3359;padding:28px;display:flex;flex-direction:column;gap:16px}.auth-brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:19px;color:var(--primary-deep)}.auth-brand .mk{width:40px;height:40px;border-radius:12px;background:var(--primary);color:#fff;display:grid;place-items:center;box-shadow:0 6px 18px #0891b266}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}.auth-input{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:12px 14px;font:inherit;font-size:15px;background:var(--card);color:var(--ink);outline:0}.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.auth-err{color:var(--danger);font-size:13px;font-weight:600}.auth-opt{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:var(--card);text-align:left;cursor:pointer}.auth-opt:hover{border-color:var(--primary)}.auth-opt b{flex:1;font-size:14px}.auth-opt .role{font-size:11px;color:var(--ink-3);font-weight:600}.btn-sec svg{width:18px;height:18px}.soon-pill{display:inline-flex;align-items:center;font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);background:var(--line-2);padding:4px 9px;border-radius:8px;flex:none}.cat-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}.cat-sect-h{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink-3);text-transform:uppercase;margin:22px 0 8px;padding-bottom:6px;border-bottom:1px solid var(--line)}.cat-list{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}.cat-row{display:grid;grid-template-columns:1fr auto auto auto;gap:10px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13px}.cat-row:last-child{border-bottom:none}.cat-row.head{background:var(--bg);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);padding:8px 14px}.cat-row-name{display:flex;flex-direction:column;gap:2px;min-width:0}.cat-row-name strong{font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-row-slug{font-size:11px;color:var(--ink-4);font-family:monospace}.cat-row-cat{font-size:12px;color:var(--ink-3);white-space:nowrap}.cat-row-price{font-size:13px;font-weight:600;color:var(--ink);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}.cat-row-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}.cat-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.cat-pill.ok{background:color-mix(in srgb,var(--ok) 12%,transparent);color:var(--ok)}.cat-pill.pending{background:color-mix(in srgb,var(--warn) 12%,transparent);color:var(--warn)}.cat-pill.reject{background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger)}.cat-req-row{display:grid;grid-template-columns:auto 1fr auto auto;gap:10px;align-items:start;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13px}.cat-req-row:last-child{border-bottom:none}.cat-req-op{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:6px;background:color-mix(in srgb,var(--accent) 12%,transparent);color:var(--accent);align-self:center;white-space:nowrap}.cat-req-info{display:flex;flex-direction:column;gap:3px;min-width:0}.cat-req-info span{font-weight:600;color:var(--ink)}.cat-req-reason{font-size:11px;color:var(--ink-3);font-style:italic}.cat-req-actions{display:flex;align-items:center;gap:6px}.cat-diff{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.cat-diff-item{font-size:10px;background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--ink-3)}.cat-diff-item em{font-style:normal;color:var(--ink);font-weight:600}.cat-feat-list{background:var(--card);border:1px solid var(--line);border-radius:10px;overflow:hidden}.cat-feat-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line);font-size:13px}.cat-feat-row:last-child{border-bottom:none}.cat-feat-name{font-weight:500;color:var(--ink)}.cat-toggle{position:relative;display:inline-flex;align-items:center;cursor:pointer}.cat-toggle input{position:absolute;opacity:0;width:0;height:0}.cat-toggle-track{display:block;width:40px;height:22px;border-radius:11px;background:var(--line);transition:background .2s;position:relative}.cat-toggle-track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.cat-toggle input:checked+.cat-toggle-track{background:var(--primary)}.cat-toggle input:checked+.cat-toggle-track:after{transform:translate(18px)}.cat-toggle input:disabled+.cat-toggle-track{opacity:.5;cursor:not-allowed}.cat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;text-align:center;color:var(--ink-4)}.cat-empty p{font-size:14px;margin:0;max-width:300px;line-height:1.5}.cat-link{background:none;border:none;padding:0;color:var(--primary);font-size:12px;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:2px;white-space:nowrap}.cat-link:hover{opacity:.8}.cat-link.danger{color:var(--danger)}.cat-loading{padding:16px 14px;font-size:13px;color:var(--ink-4);text-align:center}.cat{min-width:0}.cat .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:12px;padding:11px 16px;font:inherit;font-size:13px;font-weight:800;line-height:1;border:1px solid transparent;cursor:pointer}.cat .btn svg{width:16px;height:16px}.cat .btn.pri{background:var(--primary);color:#fff;box-shadow:0 6px 18px #0891b247}.cat .btn.pri:hover:not(:disabled){filter:brightness(1.05)}.cat .btn.ghost{background:var(--card);color:var(--ink-2);border-color:var(--line)}.cat .btn.ghost:hover{border-color:var(--primary);color:var(--primary-deep)}.cat .btn.warn{background:var(--card);color:var(--warn);border-color:var(--warn)}.cat .btn:disabled{opacity:.55;cursor:not-allowed}.cat .btn.pri:disabled{background:var(--line);color:var(--ink-4);box-shadow:none;opacity:1}.cat .scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;background:#0c2b336b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:24px}.cat .sheet{width:480px;max-width:100%;max-height:92vh;display:flex;flex-direction:column;background:var(--card);border-radius:20px;box-shadow:0 30px 80px #00000059;overflow:hidden}.cat .sheet-h{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px}.cat .sheet-h h2{margin:0;font-size:17px;font-weight:800;color:var(--ink)}.cat .sheet-h p{margin:3px 0 0;font-size:12px;color:var(--ink-3)}.cat .sheet-b{padding:18px 20px;overflow-y:auto}.cat .sheet-f{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}.cat .x{width:34px;height:34px;border-radius:10px;border:1px solid var(--line);background:var(--card);color:var(--ink-2);display:grid;place-items:center;flex:none;cursor:pointer}.cat .x svg{width:16px;height:16px}.cat .fld{display:flex;flex-direction:column;gap:7px;margin-bottom:14px}.cat .fld label{font-size:12px;font-weight:700;color:var(--ink-2)}.cat .fld input,.cat .fld select{border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;font:inherit;font-size:14px;background:var(--bg);color:var(--ink);outline:0;width:100%}.cat .fld input:focus,.cat .fld select:focus{border-color:var(--primary);background:var(--card)}.cat .fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.cat .auth-err{color:var(--danger);font-size:13px;font-weight:600;margin-top:4px}@media(max-width:560px){.cat .fld-row{grid-template-columns:1fr}.cat .scrim{padding:0;place-items:stretch}.cat .sheet{width:100%;max-width:100%;max-height:100%;height:100%;border-radius:0}.cat .sheet-f{position:sticky;bottom:0;background:var(--card)}}
