:root{--bg:#f8f1ea;--surface:#fffaf7;--surface-2:#f3e7dc;--surface-3:#efe2d3;--text:#4a2e2a;--muted:#7a5f5a;--primary:#9f5f4a;--primary-dark:#7f4638;--accent:#8d6f63;--border:#dfcdbd;--shadow:#60392c1a}*{box-sizing:border-box}body{color:var(--text);background:linear-gradient(#fbf4ef 0%,#f4ece6 100%);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;font-size:14px}.app{max-width:1280px;margin:0 auto;padding:16px}.tabs,.subtabs{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.tabs button,.subtabs button{border:1px solid var(--border);cursor:pointer;color:var(--text);background:#ffffffd9;border-radius:12px;padding:8px 12px;font-size:14px;font-weight:650;box-shadow:0 4px 12px #00000008}.tabs button.active,.subtabs button.active{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-color:var(--primary-dark)}.grid-main{grid-template-columns:1.25fr .75fr;align-items:start;gap:16px;display:grid}.card,.receipt{border:1px solid var(--border);box-shadow:0 10px 28px var(--shadow);background:#fffffff0;border-radius:22px;padding:20px}.title{align-items:center;gap:12px;margin-bottom:20px;display:flex}.title h1{margin:0;font-size:20px}.title p,.muted,.hint{color:var(--muted);margin:4px 0 0;font-size:13px}.icon{color:var(--primary-dark);background:#f2dfd2;border-radius:16px;padding:12px;display:flex}.icon.green{color:#53644e;background:#dde8d9}.icon.blue{color:#58627d;background:#e3e6ee}.icon.red{color:#8f5148;background:#f2d8d4}.form-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.field{flex-direction:column;gap:6px;font-size:13px;font-weight:650;display:flex}input,select{border:1px solid var(--border);width:100%;font:inherit;color:var(--text);background:#fff;border-radius:12px;padding:8px 10px;font-weight:500}input[readonly]{background:#f7efe9}.section-head{justify-content:space-between;align-items:center;gap:12px;margin:14px 0;display:flex}.section-head h2,.card h2,.card h1{margin:0}.line-list{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.line-row{border:1px solid var(--border);background:#fffaf799;border-radius:18px;align-items:end;gap:12px;padding:12px;display:grid}.line-row.v4{grid-template-columns:1.4fr 1.1fr 70px 110px 120px 1fr 44px}.btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:11px 14px;font-weight:850;display:inline-flex}.btn.primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;box-shadow:0 8px 18px #9f5f4a38}.btn.secondary{color:var(--text);border:1px solid var(--border);background:#fff}.full{width:100%;margin-top:12px}.actions{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.icon-button{border:1px solid var(--border);cursor:pointer;min-width:42px;height:42px;color:var(--primary-dark);background:#fff;border-radius:10px;justify-content:center;align-items:center;display:flex}.icon-button:disabled{opacity:.4;cursor:not-allowed}.receipt{background:#fffefc;font-family:Inter,Arial,Helvetica,sans-serif;font-size:12.5px}.brand-logo{flex-direction:column;align-items:center;gap:4px;margin-bottom:8px;display:flex}.logo-mark{letter-spacing:-1px;border:2px solid #1c1917;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-weight:900;display:flex}.logo-text{letter-spacing:.3px;color:var(--primary-dark);font-size:15px;font-weight:900}.center{text-align:center}.center h2{letter-spacing:.8px;margin:0 0 4px;font-size:17px}.center p{margin:2px 0;font-size:12px}hr{border:none;border-top:1px dashed #b79e8f;margin:14px 0}.mini div,.totals div{justify-content:space-between;gap:12px;margin:5px 0;display:flex}.receipt-table{grid-template-columns:1fr 32px 70px 80px;gap:8px;margin:8px 0;font-size:12px;display:grid}.receipt-table span:not(:first-child){text-align:right}.header{color:var(--primary-dark);border-bottom:1px solid #eadfd7;padding-bottom:6px;font-weight:900}.muted-line{color:#57534e;font-size:11.5px}.grand{font-size:16px;font-weight:900}.note{background:#f8efe8;border-radius:10px;padding:8px;font-size:12px}.small{color:var(--muted);font-size:11px}.thanks{font-weight:800}.qris-block{margin:12px 0 8px}.qris-image{border:1px solid #e7e5e4;border-radius:8px;width:160px;max-width:100%;margin:8px auto;display:block}.history{border:1px solid var(--border);background:#ffffffbf;border-radius:16px;grid-template-columns:1fr 120px auto;align-items:center;gap:12px;margin-top:10px;padding:12px;display:grid}.history.simple{grid-template-columns:1fr 120px}.history p{color:var(--muted);margin:4px 0 0;font-size:12px}.preview-box,.sticky-summary{border:1px solid var(--border);background:linear-gradient(#fbf2eb 0%,#f5ebe2 100%);border-radius:16px;margin:14px 0;padding:14px;font-size:14px}.sticky-summary{z-index:2;border:1px solid var(--border);position:sticky;top:0}.sticky-summary div{justify-content:space-between;gap:12px;padding:4px 0;display:flex}.sticky-summary p{color:#78716c;margin:8px 0 0;font-size:12px}.history-scroll{max-height:420px;padding-right:4px;overflow:auto}.cost-table{border:1px solid var(--border);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.cost-row{border-top:1px solid var(--border);grid-template-columns:1.2fr .8fr 1fr 1fr 1fr;align-items:center;gap:10px;padding:12px;display:grid}.cost-row:first-child{border-top:none}.cost-row.head{color:var(--primary-dark);background:#f7ebe3;font-weight:900}.dashboard{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.wide{grid-column:1/-1}.metric h2{margin:8px 0 0;font-size:24px}.metric p{color:var(--muted);margin:0}.progress{background:#ead9ca;border-radius:999px;width:100%;height:18px;margin:14px 0;overflow:hidden}.progress div{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-dark) 100%);border-radius:999px;height:100%}@media (width<=1100px){.line-row.v4{grid-template-columns:1fr 1fr}}@media (width<=900px){.grid-main,.grid-main.expenses,.dashboard,.form-grid,.form-grid.two,.line-row.v4,.history,.history.simple,.cost-row{grid-template-columns:1fr}}@media print{@page{size:80mm auto;margin:0}html,body{background:#fff;width:80mm;margin:0;padding:0}.no-print,.tabs,.subtabs,.card,.app>div:not(.grid-main){display:none!important}.app{width:80mm!important;max-width:none!important;margin:0!important;padding:0!important}.grid-main{width:80mm!important;margin:0!important;padding:0!important;display:block!important}aside{width:80mm!important;margin:0!important;padding:0!important}.receipt-print{width:80mm!important;min-width:80mm!important;max-width:80mm!important;box-shadow:none!important;color:#000!important;border:none!important;border-radius:0!important;margin:0!important;padding:8px!important;font-family:Arial,Helvetica,sans-serif!important;display:block!important}.receipt-table{grid-template-columns:1fr 28px 62px 70px;gap:5px}.qris-image{width:145px}}.history-picker{grid-template-columns:1.4fr .6fr;align-items:end;gap:14px;margin-bottom:18px;display:grid}.history-picker input[type=range]{height:38px;accent-color:var(--primary-dark);padding:0}.edit-panel{border:1px solid var(--border);background:#fff;border-radius:18px;padding:16px}.mini-title{font-size:18px;margin:18px 0 8px!important}.history-line-edit{border:1px solid var(--border);background:#fffaf7a6;border-radius:14px;grid-template-columns:1fr 80px 140px 140px;align-items:end;gap:12px;margin-bottom:10px;padding:12px;display:grid}.change-info{background:#f7ebe3;border-radius:14px;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px;padding:12px;font-size:13px;display:grid}.change-stamp{color:var(--muted);text-align:center;background:#f7efe8;border-radius:8px;margin-top:10px;padding:8px;font-size:10.5px}@media (width<=900px){.history-picker,.history-line-edit,.change-info{grid-template-columns:1fr}}.order-filter-panel{grid-template-columns:1.4fr .8fr .8fr;gap:12px;margin:14px 0;display:grid}.compact-order-list{gap:8px;max-height:220px;margin-bottom:16px;display:grid;overflow:auto}.compact-order-list button{border:1px solid var(--border);cursor:pointer;color:var(--text);background:#fff;border-radius:12px;justify-content:space-between;gap:12px;padding:10px 12px;font-weight:700;display:flex}.compact-order-list button.selected{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);color:#fff;border-color:var(--primary-dark)}.backup-actions{flex-wrap:wrap;gap:12px;margin:16px 0;display:flex}.import-label input{display:none}@media (width<=900px){.order-filter-panel{grid-template-columns:1fr}}.app{position:relative}.brand-hero{border:1px solid var(--border);box-shadow:0 10px 30px var(--shadow);background:linear-gradient(135deg,#fffaf7f2 0%,#f3e7dcf5 55%,#ece1d6f5 100%);border-radius:24px;align-items:center;gap:18px;margin-bottom:18px;padding:18px 20px;display:flex}.hero-logo{object-fit:cover;border:4px solid #ffffffd9;border-radius:50%;flex:none;width:88px;height:88px;box-shadow:0 8px 18px #60392c1f}.hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--primary);margin:0 0 4px;font-size:11px;font-weight:800}.brand-hero h1{color:var(--primary-dark);margin:0;font-size:22px}.hero-subtitle{color:var(--muted);max-width:720px;margin:6px 0 0}.title-logo{object-fit:cover;border:3px solid #ffffffe6;border-radius:50%;width:64px;height:64px;box-shadow:0 6px 14px #60392c1a}input:focus,select:focus,button:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #9f5f4a26}.receipt .brand-logo{margin-bottom:10px}.brand-logo-image{object-fit:cover;border:2px solid #d8c0b5;border-radius:50%;width:84px;height:84px;box-shadow:0 4px 10px #60392c14}.receipt .center h2,.receipt .grand{color:var(--primary-dark)}.receipt .qris-block{background:#fbf2eb;border:1px solid #ead9ca;border-radius:12px;padding:10px}.receipt .qris-image{background:#fff}@media (width<=900px){.brand-hero{text-align:center;flex-direction:column}.title-logo{width:56px;height:56px}}@media print{.brand-logo-image{width:72px!important;height:72px!important;box-shadow:none!important;border:1px solid #999!important}.logo-text{color:#000!important}}.status-paid{background:#f0f8f1!important;border-color:#9ec7a4!important}.status-paid b,.status-paid span{color:#2f6b3b}.status-unpaid,.status-down-payment{background:#fff4ef!important;border-color:#e8b4a5!important}.status-cancelled{opacity:.6}.bar-chart{gap:10px;margin-top:12px;display:grid}.bar-row{grid-template-columns:120px 1fr 120px;align-items:center;gap:12px;font-size:13px;display:grid}.bar-track{background:#ead9ca;border-radius:999px;height:18px;overflow:hidden}.bar-track div{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-dark) 100%);border-radius:999px;height:100%}.bar-track.source div{background:linear-gradient(90deg,#8d6f63 0%,#6f5b4f 100%)}.chart-card h2{color:var(--primary-dark)}@media (width<=900px){.bar-row{grid-template-columns:1fr;gap:4px}}.compact-order-list button.selected,.compact-order-list button.selected.status-paid,.compact-order-list button.selected.status-unpaid,.compact-order-list button.selected.status-down-payment,.compact-order-list button.selected.status-donation,.compact-order-list button.selected.status-cancelled{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%)!important;border-color:var(--primary-dark)!important;color:#fff!important}.compact-order-list button.selected span,.compact-order-list button.selected b{color:#fff!important}.status-donation{background:#fff8df!important;border-color:#c9b36d!important}.status-donation b,.status-donation span{color:#7a6420}body,input,select,button{font-size:14px}.card h1,.title h1{font-size:22px}.brand-hero h1{font-size:26px}.import-label{cursor:pointer}.expense-filter-panel{grid-template-columns:minmax(220px,360px) 160px;align-items:end;gap:12px;margin:16px 0;display:grid}.filter-summary{border:1px solid var(--border);background:#fffaf7;border-radius:14px;flex-direction:column;gap:2px;padding:10px 12px;display:flex}.filter-summary b{color:var(--primary-dark);font-size:18px}.filter-summary span{color:var(--muted);font-size:12px}@media (width<=900px){.expense-filter-panel{grid-template-columns:1fr}}.home-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.hero-dashboard{grid-column:1/-1;justify-content:space-between;align-items:center;gap:18px;display:flex}.hero-dashboard h1{color:var(--primary-dark);margin:0}.quick-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.status-badge{border:1px solid #0000;border-radius:999px;align-items:center;padding:3px 8px;font-size:11px;font-weight:800;line-height:1.2;display:inline-flex}.badge-paid{color:#2f6b3b;background:#e8f5eb;border-color:#9ec7a4}.badge-unpaid{color:#9a4a35;background:#fff1ec;border-color:#e8b4a5}.badge-down-payment{color:#856113;background:#fff7d6;border-color:#e5c75e}.badge-donation{color:#674083;background:#f6edff;border-color:#d8bcef}.badge-cancelled{color:#6b6b6b;background:#f1f1f1;border-color:#d1d1d1}.order-summary-box{border:1px solid var(--border);background:linear-gradient(#fbf2eb 0%,#f5ebe2 100%);border-radius:16px;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px;padding:14px;display:grid}.order-summary-box div{flex-direction:column;gap:4px;display:flex}.order-summary-box span{color:var(--muted);font-size:12px}.order-summary-box b{color:var(--primary-dark);font-size:15px}.confirm-overlay{z-index:1000;background:#2c191261;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.confirm-card{border:1px solid var(--border);background:#fff;border-radius:24px;width:min(520px,100%);padding:22px;box-shadow:0 20px 55px #2c191240}.confirm-card h2{color:var(--primary-dark);margin:0 0 6px}.customer-table{border:1px solid var(--border);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.customer-row{border-top:1px solid var(--border);grid-template-columns:1.2fr 1fr .6fr .9fr .8fr .8fr;align-items:center;gap:10px;padding:12px;display:grid}.customer-row:first-child{border-top:none}.customer-row.head{color:var(--primary-dark);background:#f7ebe3;font-weight:900}.dual-bar-chart{gap:12px;margin-top:12px;display:grid}.dual-row{grid-template-columns:120px 1fr 120px;align-items:center;gap:12px;display:grid}.dual-bars{gap:4px;display:grid}.bar-sales,.bar-expense{border-radius:999px;height:10px}.bar-sales{background:linear-gradient(90deg, var(--primary) 0%, var(--primary-dark) 100%)}.bar-expense{background:linear-gradient(90deg,#d8b89d 0%,#a98467 100%)}@media (width<=1000px){.home-grid,.dashboard{grid-template-columns:repeat(2,1fr)}.hero-dashboard{flex-direction:column;align-items:flex-start}.quick-actions{justify-content:flex-start}.order-summary-box{grid-template-columns:repeat(2,1fr)}.customer-row{grid-template-columns:1fr 1fr}}@media (width<=640px){.home-grid,.dashboard,.order-summary-box,.dual-row{grid-template-columns:1fr}}.sync-status{border:1px solid var(--border);color:var(--primary-dark);background:#ffffffb8;border-radius:999px;margin-top:8px;padding:6px 10px;font-size:12px;font-weight:800;display:inline-flex}.production-summary{grid-template-columns:repeat(3,1fr);gap:12px;margin:16px 0;display:grid}.production-summary div{border:1px solid var(--border);background:#fffaf7;border-radius:16px;flex-direction:column;gap:4px;padding:14px;display:flex}.production-summary span{color:var(--muted);font-size:12px;font-weight:700}.production-summary b{color:var(--primary-dark);font-size:20px}.production-list{gap:10px;display:grid}.production-item{border:1px solid var(--border);background:linear-gradient(#fffaf7 0%,#f8efe8 100%);border-radius:16px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;font-weight:800;display:flex}.production-item b{color:var(--primary-dark);font-size:20px}.production-order{border:1px solid var(--border);background:#fffaf7;border-radius:16px;margin-top:10px;padding:14px}.production-order-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.production-order p{color:var(--muted);margin:6px 0 10px;font-size:13px}.summary-row{border-top:1px dashed var(--border);justify-content:space-between;gap:12px;padding:6px 0;display:flex}.summary-row:first-of-type{border-top:none}@media (width<=900px){.production-summary{grid-template-columns:1fr}}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}.app,.grid-main,.card,.receipt,aside,.field,.history-line-edit,.form-grid,.order-filter-panel,.history-picker,input,select,button,.btn{min-width:0;max-width:100%}.card,.receipt{overflow-wrap:anywhere}.line-remove-btn{white-space:nowrap;align-self:end}.item-edit-actions{justify-content:flex-start;margin:2px 0 14px;display:flex}@media (width<=1180px){.app{padding:12px}.grid-main,.grid-main.expenses{grid-template-columns:1fr}aside{width:100%}.receipt{width:min(100%,520px);margin:0 auto}}@media (width<=760px){.card,.receipt{border-radius:18px;padding:14px}.history-line-edit,.form-grid,.form-grid.two,.order-filter-panel,.history-picker,.change-info{grid-template-columns:1fr!important}.actions,.backup-actions,.item-edit-actions{flex-direction:column;align-items:stretch}.actions .btn,.backup-actions .btn,.item-edit-actions .btn{width:100%}}html,body{max-width:100%;overflow-x:hidden}.app,.grid-main,.grid-main>*,.card,.receipt,aside,.field,.form-grid,.history-line-edit,.history,.compact-order-list button{min-width:0}.grid-main{grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr)}.grid-main.expenses{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.form-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.field>span{min-width:0}input,select{min-width:0;max-width:100%}.history-line-edit{grid-template-columns:minmax(0,1.6fr) 90px 140px 140px 132px}.line-remove-btn{width:100%}.item-edit-actions{flex-wrap:wrap;gap:10px;margin:10px 0 16px;display:flex}.compact-order-list button span,.history p{overflow-wrap:anywhere;min-width:0}.modal-overlay{z-index:1000;background:#4a2e2a6b;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.celebration-modal{border:1px solid var(--border);text-align:center;background:linear-gradient(#fffaf7 0%,#f7ede5 100%);border-radius:28px;width:min(100%,420px);padding:28px 24px 24px;position:relative;box-shadow:0 20px 50px #4a2e2a2e}.modal-close{border:1px solid var(--border);width:36px;height:36px;color:var(--primary-dark);cursor:pointer;background:#fff;border-radius:999px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:12px;right:12px}.celebration-image{object-fit:cover;border:4px solid #fffffff2;border-radius:50%;width:108px;height:108px;margin-bottom:12px;box-shadow:0 12px 24px #60392c26}.celebration-eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--primary);margin:0 0 8px;font-size:11px;font-weight:800}.celebration-modal h2{color:var(--primary-dark);margin:0;font-size:30px}.celebration-text{color:var(--text);margin:10px 0 0;font-size:17px;font-weight:700}.celebration-meta{flex-wrap:wrap;justify-content:center;gap:8px;margin:16px 0 18px;display:inline-flex}.celebration-meta span{border:1px solid var(--border);background:#fffc;border-radius:999px;padding:6px 10px;font-weight:700}@media (width<=1280px){.edit-panel .form-grid.two,.history-line-edit,.change-info{grid-template-columns:1fr}}@media (width<=1100px){.form-grid,.line-row.v4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=900px){.app{padding:12px}.grid-main,.grid-main.expenses,.dashboard,.form-grid,.form-grid.two,.line-row.v4,.history,.history.simple,.cost-row,.history-picker,.order-filter-panel,.history-line-edit,.change-info{grid-template-columns:1fr}}@media (width<=640px){.card,.receipt{border-radius:18px;padding:16px}.brand-hero{flex-direction:column;align-items:flex-start}.actions,.backup-actions{flex-direction:column}.actions .btn,.backup-actions .btn,.item-edit-actions .btn{width:100%}.celebration-modal{border-radius:22px;padding:24px 18px 20px}.celebration-modal h2{font-size:26px}.celebration-text{font-size:15px}}.hero-badges{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.hero-badges span,.soft-pill{border:1px solid var(--border);color:var(--primary-dark);background:#ffffffb8;border-radius:999px;align-items:center;padding:6px 10px;font-size:12px;font-weight:850;display:inline-flex}.tabs{z-index:60;-webkit-backdrop-filter:blur(12px);background:#fffaf7d1;border:1px solid #dfcdbdd1;border-radius:18px;padding:8px;position:sticky;top:8px;box-shadow:0 10px 26px #60392c14}.tabs button,.subtabs button,.btn,.quick-nav-card,.compact-order-list button{transition:transform .16s,box-shadow .16s,border-color .16s,background .16s}.tabs button:hover,.subtabs button:hover,.btn:hover,.quick-nav-card:hover,.compact-order-list button:hover{transform:translateY(-1px);box-shadow:0 8px 18px #60392c1a}.quick-nav-panel{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin:0 0 16px;display:grid}.quick-nav-card{border:1px solid var(--border);color:var(--text);text-align:left;cursor:pointer;background:#ffffffdb;border-radius:18px;align-items:center;gap:10px;min-width:0;padding:12px;display:flex}.quick-nav-card.active{border-color:var(--primary-dark);background:linear-gradient(135deg,#9f5f4a29 0%,#fffffff0 100%)}.quick-nav-icon{background:#f7ebe3;border-radius:12px;flex:0 0 36px;justify-content:center;align-items:center;width:36px;height:36px;font-size:19px;display:inline-flex}.quick-nav-card b,.quick-nav-card small{display:block}.quick-nav-card b{color:var(--primary-dark);font-size:13px}.quick-nav-card small{color:var(--muted);margin-top:2px;font-size:11.5px}.workflow-card{background:linear-gradient(135deg,#fffaf7f5 0%,#f6ebe2f5 100%)}.workflow-head{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.workflow-head h2{color:var(--primary-dark);margin:0}.workflow-steps{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.workflow-steps div{border:1px solid var(--border);background:#ffffffbd;border-radius:16px;padding:12px}.workflow-steps b,.workflow-steps span{display:block}.workflow-steps b{color:var(--primary-dark);margin-bottom:4px}.workflow-steps span{color:var(--muted);font-size:12px}.card,.receipt{transition:transform .18s,box-shadow .18s}.card:hover{box-shadow:0 14px 32px #60392c1f}.metric h2{letter-spacing:-.02em}.bar-track{box-shadow:inset 0 1px 2px #60392c14}.scroll-top{border:1px solid var(--border);width:46px;height:46px;color:var(--primary-dark);cursor:pointer;z-index:55;background:#fffaf7eb;border-radius:999px;font-size:22px;font-weight:900;position:fixed;bottom:18px;right:18px;box-shadow:0 12px 28px #60392c29}.celebration-modal{overflow:hidden}.celebration-sparkles{pointer-events:none;position:absolute;inset:0}.celebration-sparkles span{color:#9f5f4a6b;font-weight:900;animation:2.8s ease-in-out infinite floatSparkle;position:absolute}.celebration-sparkles span:first-child{animation-delay:0s;top:18%;left:16%}.celebration-sparkles span:nth-child(2){animation-delay:.35s;top:16%;right:18%}.celebration-sparkles span:nth-child(3){animation-delay:.65s;bottom:22%;left:18%}.celebration-sparkles span:nth-child(4){animation-delay:.95s;bottom:25%;right:16%}@keyframes floatSparkle{0%,to{opacity:.52;transform:translateY(0)scale(1)}50%{opacity:1;transform:translateY(-10px)scale(1.16)}}@media (width<=1180px){.quick-nav-panel{grid-template-columns:repeat(3,minmax(0,1fr))}.workflow-steps{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.quick-nav-panel,.workflow-steps{grid-template-columns:1fr}.tabs{position:static}.quick-nav-card{padding:11px}.workflow-head{flex-direction:column}.scroll-top{width:42px;height:42px;bottom:12px;right:12px}}.cash-sound-label{color:#8b552d;letter-spacing:.03em;background:#fff4df;border:1px solid #edd5b2;border-radius:999px;justify-content:center;align-items:center;gap:6px;margin:2px auto 8px;padding:7px 12px;font-weight:900;display:inline-flex;box-shadow:0 8px 18px #8b552d1a}.celebration-note{color:var(--muted);margin:8px 0 0;font-size:13px;font-weight:700}.quick-nav-panel{display:none!important}.clean-home-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.clean-home-head h1{color:var(--primary-dark);margin:0 0 6px}.compact-actions{justify-content:flex-end}.home-dashboard{margin-top:20px}@media (width<=900px){.clean-home-head{flex-direction:column;align-items:stretch}.compact-actions{justify-content:flex-start}}.login-page{background:radial-gradient(circle at 0 0,#a55c482e,#0000 32%),linear-gradient(135deg,#fff8f2 0%,#f7ede7 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{border:1px solid var(--border);background:#ffffffe0;border-radius:30px;width:min(100%,430px);padding:30px;box-shadow:0 24px 60px #4f2e2629}.login-logo{object-fit:cover;border-radius:50%;width:92px;height:92px;margin:0 auto 14px;display:block;box-shadow:0 12px 30px #4f2e2629}.login-card h1{text-align:center;color:var(--primary-dark);margin:0 0 8px}.login-card .hero-eyebrow,.login-subtitle,.login-note{text-align:center}.login-subtitle{color:var(--muted);margin:0 0 22px;line-height:1.45}.login-error{color:#9a3f2e;background:#fff0ed;border:1px solid #f0b5aa;border-radius:14px;margin:10px 0;padding:10px 12px;font-weight:700}.login-button{justify-content:center;width:100%;margin-top:12px}.login-note{color:var(--muted);margin:14px 0 0;font-size:13px}.logout-pill{border:1px solid var(--border);color:var(--primary-dark);cursor:pointer;background:#fff;border-radius:999px;padding:9px 14px;font-weight:800}.logout-pill:hover{border-color:var(--primary);box-shadow:0 8px 18px #4f2e2617}@media (width<=640px){.login-page{padding:14px}.login-card{border-radius:24px;padding:22px}}.public-order-page{min-height:100vh;color:var(--text);background:radial-gradient(circle at 0 0,#fff6ef 0,#f3e2d5 44%,#efe6de 100%);padding:20px}.public-order-shell{max-width:980px;margin:0 auto}.public-order-hero{text-align:center;padding:24px 10px 18px}.public-logo{object-fit:cover;border-radius:28px;width:96px;height:96px;box-shadow:0 12px 28px #4a2e2a24}.public-order-hero h1{color:var(--primary-dark);margin:10px 0 6px;font-size:clamp(30px,5vw,48px)}.public-order-hero p{max-width:580px;color:var(--muted);margin:0 auto}.public-order-form{gap:16px;display:grid}.public-order-form textarea,.public-order-form input,.public-order-form select{font-size:16px}.customer-line-row{grid-template-columns:minmax(0,1.4fr) 120px 140px 120px;align-items:end;gap:12px;margin-bottom:12px;display:grid}.line-mini-total{border:1px solid var(--border);background:#fffaf7;border-radius:16px;flex-direction:column;justify-content:center;min-height:48px;padding:10px 12px;display:flex}.line-mini-total span{color:var(--muted);font-size:12px;font-weight:700}.public-summary-card{z-index:2;position:sticky;bottom:12px}.public-success-card{text-align:center;max-width:620px;margin:0 auto}.pending-order-card{min-width:0}.pending-head{justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px;display:flex}.pending-head h2{margin:0}.pending-head p{color:var(--muted);margin:4px 0 0}.mini-table{border:1px solid var(--border);border-radius:16px;margin:12px 0;overflow:hidden}.mini-table>div{border-bottom:1px solid var(--border);background:#fff;grid-template-columns:minmax(0,1.3fr) minmax(0,.8fr) minmax(0,.8fr);gap:10px;padding:10px 12px;display:grid}.mini-table>div:last-child{border-bottom:0}.mini-table span,.mini-table b{overflow-wrap:anywhere}.pending-note{border:1px solid var(--border);background:#fffaf7;border-radius:14px;padding:10px 12px}.btn.secondary[href]{justify-content:center;align-items:center;text-decoration:none;display:inline-flex}@media (width<=760px){.public-order-page{padding:12px}.customer-line-row{grid-template-columns:1fr}.public-summary-card{position:static}.pending-head{flex-direction:column}.mini-table>div{grid-template-columns:1fr}}.customer-order-link{border:1px solid var(--border);width:100%;color:var(--primary-dark);background:#ffffffbd;border-radius:14px;justify-content:center;align-items:center;margin-top:12px;padding:13px 16px;font-weight:800;text-decoration:none;display:inline-flex}.customer-order-link:hover{border-color:#a0564580;box-shadow:0 10px 22px #5a332a14}.login-card .login-subtitle{text-transform:none}.public-admin-link{border:1px solid var(--border);color:var(--primary-dark);background:#ffffffc7;border-radius:999px;justify-content:center;align-items:center;margin-top:14px;padding:10px 16px;font-weight:800;text-decoration:none;display:inline-flex;box-shadow:0 8px 18px #64483c14}.public-admin-link:hover{transform:translateY(-1px)}

/* v21 mobile customer order upgrade */
.product-card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:8px 0 18px;display:grid}.product-card{border:1px solid var(--border);background:linear-gradient(180deg,#fffaf7 0%,#f7ebe3 100%);border-radius:22px;padding:14px;box-shadow:0 10px 22px #60392c12;overflow:hidden}.product-card img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:18px;border:1px solid #ead9ca;background:#fff}.product-card h3{color:var(--primary-dark);margin:12px 0 4px;font-size:17px}.product-card p{color:var(--muted);margin:0 0 12px;line-height:1.35}.product-card-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.product-card-actions button{border:1px solid #b98778;background:#fffaf7;color:var(--primary-dark);border-radius:999px;padding:10px 9px;font:inherit;font-size:13px;font-weight:900;cursor:pointer}.product-card-actions button:hover{background:#9f5f4a;color:#fff;border-color:#9f5f4a}.public-success-card .qris-image{width:220px}.public-success-card .order-recap-box{text-align:left}.public-summary-card:before{content:'Keranjang order';display:block;color:var(--primary-dark);font-weight:900;margin-bottom:6px}.public-order-form input:required,.public-order-form select:required{border-color:#cfae9f}.public-order-form .field label:has(+ input:required)::after{content:' *';color:#a33e2c}@media (width<=760px){.public-order-hero{padding-top:14px}.public-logo{width:76px;height:76px}.public-order-hero h1{font-size:34px;line-height:1.05}.product-card-grid{grid-template-columns:1fr}.product-card{border-radius:20px;padding:12px}.product-card-actions{grid-template-columns:1fr}.public-summary-card{position:sticky;bottom:10px;border-radius:20px;background:#fffaf7f2;box-shadow:0 -8px 24px #60392c1c}.public-success-card .qris-image{width:240px;max-width:82vw}.public-success-card{border-radius:22px;padding:18px}.qris-block.public-qris-block{padding:14px}}

/* v21 default thermal receipt print 58mm */
@media print{@page{size:58mm auto;margin:0}html,body{width:58mm!important;margin:0!important;padding:0!important;background:#fff!important}.app,.grid-main,aside{width:58mm!important;max-width:58mm!important;margin:0!important;padding:0!important}.receipt-print{width:58mm!important;min-width:58mm!important;max-width:58mm!important;padding:5mm 3mm!important;font-size:10.5px!important;line-height:1.25!important}.receipt .brand-logo-image{width:48px!important;height:48px!important}.receipt .center h2{font-size:13px!important}.receipt-table{grid-template-columns:1fr 18px 38px 42px!important;gap:3px!important;font-size:9.5px!important}.receipt .qris-image,.qris-image{width:112px!important}.mini div,.totals div{gap:6px!important}.grand{font-size:13px!important}}

/* v22: explicit Print 58mm button labels in app */
.version-note{margin:18px auto 10px;text-align:center;font-size:12px;color:#8a6b60}.edit-warning{padding:10px 12px;border:1px dashed #d8c8bf;border-radius:14px;background:#fff8f5;color:#6f4c43;font-size:13px;margin-bottom:12px}.actions .btn[title]{min-width:46px;justify-content:center}.actions .btn{gap:6px}
.filter-chip-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.chip{border:1px solid var(--line,#e0cfc3);background:#fff;border-radius:999px;padding:8px 12px;font-weight:700;color:#6b4638}.chip.active,.active.chip{background:#9a5747;color:#fff;border-color:#9a5747}.order-filter-panel .btn{align-self:end}
