@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=DM+Mono:wght@400;500&display=swap";
:root{--bg-base:#f5f3f0;--bg-surface:#fff;--bg-raised:#faf9f7;--bg-overlay:#fffcf8eb;--border:#e0d9d0;--border-soft:#ece8e2;--border-strong:#c8bfb4;--text-900:#1c1814;--text-700:#3d3630;--text-500:#7a706a;--text-300:#b8b0a8;--brand:#7c5c3e;--brand-light:#a07850;--brand-dim:#7c5c3e1a;--brand-glow:0 4px 18px #7c5c3e33;--brand-gradient:linear-gradient(135deg,#7c5c3e 0%,#a07850 100%);--success:#3a8c5c;--success-bg:#3a8c5c1a;--warning:#c2820a;--warning-bg:#c2820a1a;--danger:#c44040;--danger-bg:#c440401a;--info:#2e6fa8;--info-bg:#2e6fa81a;--bg-primary:var(--bg-base);--bg-secondary:var(--bg-surface);--border-color:var(--border);--border-light:var(--border-soft);--text-primary:var(--text-900);--text-secondary:var(--text-700);--text-muted:var(--text-500);--accent-primary:var(--brand);--accent-secondary:var(--brand-light);--color-success:var(--success);--bg-danger:var(--danger-bg);--text-danger:var(--danger);--primary:var(--brand);--r-xs:6px;--r-sm:10px;--r:14px;--r-lg:20px;--r-xl:28px;--r-md:var(--r);--font-mono:"DM Mono",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--shadow-xs:0 1px 2px #1c18140d;--shadow-sm:0 2px 8px #1c181412,0 1px 2px #1c18140a;--shadow:0 4px 16px #1c181414,0 1px 4px #1c18140a;--shadow-lg:0 12px 40px #1c18141a,0 4px 12px #1c18140d;--shadow-xl:0 24px 64px #1c18141f,0 8px 24px #1c181412;--ease:cubic-bezier(.22,1,.36,1);--transition:all .2s var(--ease);--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-base);color:var(--text-900);-webkit-font-smoothing:antialiased;min-height:100vh;text-rendering:optimizeLegibility;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.5}body{overflow-x:hidden}a,button{-webkit-tap-highlight-color:transparent}*{overflow-wrap:anywhere}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-300)}.app-layout{min-height:100vh;display:flex;position:relative}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);z-index:1050;transition:width .3s var(--ease),transform .3s var(--ease);box-shadow:var(--shadow-sm);padding-bottom:env(safe-area-inset-bottom,20px);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;padding:20px 16px;display:flex}.sidebar-header.collapsed{justify-content:center;padding:20px 12px}.sidebar-header.collapsed .sidebar-logo{display:none}.sidebar-logo{align-items:center;gap:10px;display:flex}.sidebar-logo .logo-icon{background:var(--brand-gradient);border-radius:var(--r-sm);width:38px;height:38px;box-shadow:var(--brand-glow);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.sidebar-logo .logo-text{color:var(--brand);letter-spacing:-.4px;font-size:17px;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex;overflow-y:auto}.nav-link{border-radius:var(--r-sm);color:var(--text-500);transition:var(--transition);cursor:pointer;align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.nav-link:hover{background:var(--bg-base);color:var(--text-700)}.nav-link.active{background:var(--brand-dim);color:var(--brand);font-weight:600}.nav-link.active:before{content:"";background:var(--brand-gradient);border-radius:0 3px 3px 0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.nav-link .nav-icon{text-align:center;flex-shrink:0;width:22px;font-size:17px}.nav-link.collapsed{justify-content:center;padding:10px}.sidebar-toggle{color:var(--text-500);cursor:pointer;border-radius:var(--r-xs);transition:var(--transition);background:0 0;border:none;justify-content:center;align-items:center;width:30px;height:30px;padding:4px;font-size:18px;display:flex}.sidebar-toggle:hover{background:var(--bg-base);color:var(--text-900)}.main-content{margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left .3s var(--ease),width .3s var(--ease);width:calc(100% - var(--sidebar-width));flex:1;padding:20px 28px 80px}.mobile-toggle-btn{display:none}.page-header{flex-direction:column;gap:2px;margin-bottom:16px;display:flex}.header-main{align-items:center;gap:12px;display:flex}.page-header h1{color:var(--text-900);letter-spacing:-.5px;margin:0;font-size:22px;font-weight:800}.page-header .subtitle{color:var(--text-500);font-size:13px;font-weight:400}.page-header p{color:var(--text-500);margin-top:2px;font-size:13px;font-weight:400}.btn-draft-header{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-700);cursor:pointer;transition:var(--transition);width:fit-content;box-shadow:var(--shadow-xs);align-items:center;gap:6px;margin-top:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-draft-header:hover{background:var(--bg-base);border-color:var(--border-strong)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);transition:var(--transition);box-shadow:var(--shadow-xs);padding:20px}.stat-card:hover{box-shadow:var(--shadow);border-color:var(--border-strong);transform:translateY(-2px)}.stat-card .stat-icon{border-radius:var(--r-sm);justify-content:center;align-items:center;width:42px;height:42px;margin-bottom:14px;font-size:19px;display:flex}.stat-card .stat-icon.purple{background:var(--brand-dim);color:var(--brand)}.stat-card .stat-icon.blue{background:var(--info-bg);color:var(--info)}.stat-card .stat-icon.green{background:var(--success-bg);color:var(--success)}.stat-card .stat-icon.orange{background:var(--warning-bg);color:var(--warning)}.stat-card .stat-value{letter-spacing:-.5px;color:var(--text-900);margin-bottom:3px;font-size:22px;font-weight:800}.stat-card .stat-label{color:var(--text-500);font-size:12.5px;font-weight:500}.glass-card{background:var(--bg-overlay);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-soft);border-radius:var(--r);box-shadow:var(--shadow-sm);padding:22px}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);padding:22px}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-header h2{color:var(--text-900);letter-spacing:-.2px;font-size:15px;font-weight:700}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--text-500);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:700}tbody td{border-bottom:1px solid var(--border-soft);vertical-align:middle;padding:11px 14px;font-size:13.5px}tbody tr{transition:background .15s}tbody tr:hover{background:var(--bg-raised)}tbody tr:last-child td{border-bottom:none}.btn{border-radius:var(--r-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;letter-spacing:-.1px;border:none;justify-content:center;align-items:center;gap:7px;padding:10px 20px;font-family:inherit;font-size:13.5px;font-weight:600;display:inline-flex}.btn-primary{background:var(--brand-gradient);color:#fff;box-shadow:var(--brand-glow)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #7c5c3e59}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-surface);color:var(--text-700);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.btn-secondary:hover{background:var(--bg-base);border-color:var(--border-strong);color:var(--text-900)}.btn-success{background:var(--success);color:#fff;box-shadow:0 4px 14px #3a8c5c40}.btn-success:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3a8c5c59}.btn-danger{color:var(--danger);background:0 0;border:1px solid #c440404d}.btn-danger:hover{background:var(--danger-bg);border-color:var(--danger)}.btn-sm{padding:6px 13px;font-size:12.5px}.btn-lg{padding:13px 26px;font-size:15px}.btn-icon{border-radius:var(--r-sm);width:34px;height:34px;padding:0}.input-group{flex-direction:column;gap:5px;display:flex}.input-row{align-items:center;gap:10px;display:flex}@media (max-width:768px){.input-row{flex-direction:column;align-items:stretch}}.input-group label{color:var(--text-700);font-size:12.5px;font-weight:600}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--text-700);font-size:12.5px;font-weight:600}.form-control{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-900);transition:var(--transition);box-shadow:var(--shadow-xs);outline:none;padding:9px 13px;font-family:inherit;font-size:13.5px}.form-control:hover{border-color:var(--border-strong)}.form-control:focus{border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px #7c5c3e1a}input[type=text],input[type=number],input[type=search],input[type=date],input[type=password],select,textarea{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--r-sm);width:100%;color:var(--text-900);transition:var(--transition);box-shadow:var(--shadow-xs);outline:none;padding:9px 13px;font-family:inherit;font-size:13.5px}input:hover,select:hover,textarea:hover{border-color:var(--border-strong)}input:focus,select:focus,textarea:focus{border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px #7c5c3e1a}input::placeholder{color:var(--text-300)}.search-bar{align-items:center;margin:12px 16px;display:flex;position:relative}.search-bar input{width:100%;box-shadow:var(--shadow-xs);background:#fff;border:1px solid #e2e8f0;border-radius:12px;outline:none;padding:10px 16px 10px 40px;font-size:14px}.search-bar .search-icon{color:#64748b;pointer-events:none;position:absolute;left:14px}.badge{border-radius:20px;align-items:center;padding:3px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.pos-layout{grid-template-columns:1fr;gap:0;display:grid}.pos-products{flex-direction:column;display:flex}.pos-products .products-header{gap:10px;margin-bottom:10px;display:flex}.category-filter-bar{scrollbar-width:none;background:#fff;gap:10px;padding:12px 16px;display:flex;overflow-x:auto}.category-filter-bar::-webkit-scrollbar{display:none}.category-pill{white-space:nowrap;color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:8px 20px;font-size:14px;font-weight:600;transition:all .2s}.category-pill:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}.category-pill.active{color:#fff;background:#8b6e58;border-color:#8b6e58}.products-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:12px;padding:16px 24px 180px;display:grid}.product-card{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--r);cursor:pointer;transition:var(--transition);text-align:center;box-shadow:var(--shadow-xs);flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex;position:relative}.product-card:hover{background:var(--bg-raised);box-shadow:var(--shadow-sm);border-color:var(--border)}.product-card.active{background:#3a8c5c14;border-color:#3a8c5c59}.product-initials{background:var(--brand-dim);width:52px;height:52px;color:var(--brand);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:800;display:flex}.product-info{flex-direction:column;flex:1;display:flex}.product-card .product-name{color:var(--text-900);letter-spacing:-.2px;white-space:nowrap;text-overflow:ellipsis;flex:1;margin-bottom:2px;font-size:13px;font-weight:700;line-height:1.3;overflow:hidden}.product-card .product-meta{color:#64748b;align-items:center;gap:6px;font-size:12px;display:flex}.product-card .product-price{color:var(--success);letter-spacing:-.4px;font-family:Inter,sans-serif;font-size:13px;font-weight:800}.product-card .product-code{color:var(--brand-light);text-transform:uppercase;letter-spacing:.8px;margin-bottom:7px;font-family:DM Mono,monospace;font-size:10.5px;font-weight:500}.product-badge{background:var(--brand-gradient);color:#fff;z-index:5;border:2px solid var(--bg-surface);border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;font-family:DM Mono,monospace;font-size:11px;font-weight:700;display:flex;position:absolute;top:10px;right:10px;box-shadow:0 2px 8px #7c5c3e4d}.selection-cart-pill{min-width:320px;max-width:90vw;transition:all .3s cubic-bezier(.4,0,.2,1);bottom:24px;width:auto!important;padding:14px 24px calc(14px + env(safe-area-inset-bottom))!important;z-index:990!important;color:#fff!important;background:#10b981!important;border:none!important;border-radius:20px!important;justify-content:space-between!important;align-items:center!important;margin:0!important;display:flex!important;position:fixed!important;left:50%!important;transform:translate(-50%)!important;box-shadow:0 12px 40px #10b98173!important}.selection-cart-pill .btn-primary{cursor:pointer;color:#fff!important;background:#fff3!important;border:none!important;border-radius:14px!important;align-items:center!important;gap:8px!important;height:auto!important;padding:10px 20px!important;font-size:15px!important;font-weight:700!important;display:flex!important}.selection-cart-pill .btn-primary:hover{transform:scale(1.02);background:#ffffff4d!important}.selection-cart-pill .cart-info{align-items:center;gap:10px;font-size:19px;font-weight:700;display:flex}.selection-cart-pill .product-count-label{opacity:.9;font-size:14px;font-weight:400}@media (max-width:768px){.selection-cart-pill{min-width:unset;bottom:20px;border-radius:16px!important;left:16px!important;right:16px!important;transform:none!important}}.pos-cart{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--r-lg);height:100%;min-height:400px;max-height:calc(100vh - 120px);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.receipt-container{width:100%}.cart-header{border-bottom:1px solid var(--border-soft);background:var(--bg-raised);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.cart-header h2{color:var(--text-900);align-items:center;gap:8px;font-size:14.5px;font-weight:700;display:flex}.cart-count{background:var(--brand-gradient);color:#fff;width:22px;height:22px;box-shadow:var(--brand-glow);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.cart-items{flex:1;padding:8px 0 160px;overflow-y:auto}.cart-item{align-items:center;gap:10px;padding:9px 16px;transition:background .15s;display:flex}.cart-item:hover{background:var(--bg-raised)}.cart-item-info{flex:1;min-width:0}.cart-item-info .item-name{white-space:nowrap;text-overflow:ellipsis;color:var(--text-900);font-size:13px;font-weight:600;overflow:hidden}.cart-item-info .item-price{color:var(--text-500);margin-top:2px;font-family:DM Mono,monospace;font-size:11.5px}.cart-item-qty{align-items:center;gap:7px;display:flex}.cart-item-qty button{border-radius:var(--r-xs);border:1.5px solid var(--border);background:var(--bg-base);width:26px;height:26px;color:var(--text-700);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.cart-item-qty button:hover{border-color:var(--brand);background:var(--brand-dim);color:var(--brand)}.cart-item-qty .qty-value{text-align:center;min-width:18px;font-family:DM Mono,monospace;font-size:13.5px;font-weight:700}.cart-item-subtotal{color:var(--success);white-space:nowrap;font-family:DM Mono,monospace;font-size:13.5px;font-weight:700}.cart-item-actions-group{align-items:center;gap:8px;display:flex}.cart-item-action-btn{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--r-xs);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;padding:4px 6px;font-size:14px;display:flex}.cart-item-action-btn:hover{border-color:var(--brand);background:var(--brand-dim)}.cart-item-remove{color:var(--text-300);cursor:pointer;transition:var(--transition);border-radius:var(--r-xs);background:0 0;border:none;padding:3px;font-size:15px}.cart-item-remove:hover{color:var(--danger);background:var(--danger-bg)}.cart-empty{color:var(--text-300);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.cart-empty .empty-icon{opacity:.25;margin-bottom:12px;font-size:44px}.cart-footer{border-top:1px solid var(--border-soft);padding:16px 18px calc(16px + env(safe-area-inset-bottom));background:var(--bg-surface);z-index:20;margin-top:auto;position:sticky;bottom:0;box-shadow:0 -8px 24px #1c18140f}.sticky-actions{background:var(--bg-surface);z-index:20;border-top:1px solid var(--border-soft);padding:14px 16px;position:sticky;bottom:0;box-shadow:0 -8px 24px #1c18140f}.cart-summary{margin-bottom:14px}.cart-actions{gap:10px;margin-top:12px;display:flex}.cart-summary-row{color:var(--text-500);justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.cart-summary-row span:last-child{font-family:DM Mono,monospace;font-size:12.5px}.cart-summary-row.total{color:var(--text-900);border-top:1.5px solid var(--border);letter-spacing:-.3px;margin-top:8px;padding-top:12px;font-size:17px;font-weight:800}.cart-summary-row.total span:last-child{color:var(--brand);font-family:DM Mono,monospace;font-size:16px}.payment-section{margin-top:12px}.payment-section .payment-input{gap:7px;margin-bottom:10px;display:flex}.payment-section .payment-input input{flex:1}.kembalian-row{border-radius:var(--r-sm);background:#7c5c3e12;border:1px solid #7c5c3e2e;justify-content:space-between;align-items:center;margin-bottom:10px;padding:8px 12px;font-size:14.5px;font-weight:700;display:flex}.kembalian-row .kembalian-value{color:var(--success);font-family:DM Mono,monospace;font-size:16px}.quick-cash{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:12px;display:grid}.quick-cash button{border:1.5px solid var(--border);background:var(--bg-base);color:var(--text-700);border-radius:var(--r-sm);cursor:pointer;transition:var(--transition);padding:7px;font-family:DM Mono,monospace;font-size:11.5px;font-weight:600}.quick-cash button:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}.receipt-preview{color:#111;border-radius:var(--r);width:58mm;box-shadow:var(--shadow-lg);z-index:10;margin:0 auto;padding:24px;font-family:DM Mono,Courier New,monospace;font-size:11.5px;position:relative;background:#fff!important}.receipt-preview .receipt-header{text-align:center;border-bottom:1px dashed #bbb;margin-bottom:10px;padding-bottom:10px}.receipt-preview .receipt-header h3{font-family:Inter,sans-serif;font-size:15px;font-weight:700}.receipt-preview .receipt-header p{color:#555;font-size:11px}.receipt-preview .receipt-meta{border-bottom:1px dashed #bbb;margin-bottom:10px;padding-bottom:10px;font-size:11px}.receipt-preview .receipt-items{border-bottom:1px dashed #bbb;margin-bottom:10px;padding-bottom:10px}.receipt-preview .receipt-item{margin-bottom:6px}.receipt-preview .receipt-item .item-line{justify-content:space-between;display:flex}.receipt-preview .receipt-item .item-detail{color:#666;font-size:10.5px}.receipt-preview .receipt-total{margin-bottom:10px}.receipt-preview .receipt-total .total-line{justify-content:space-between;padding:2px 0;display:flex}.receipt-preview .receipt-total .grand-total{border-top:1px solid #333;margin-top:4px;padding-top:4px;font-size:13px;font-weight:700}.receipt-preview .receipt-footer{text-align:center;color:#555;border-top:1px dashed #bbb;margin-top:10px;padding-top:10px;font-size:11px}.modal-overlay{z-index:2000;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0;-webkit-backdrop-filter:blur(12px)!important;background:#12100ebf!important}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);width:90%;max-width:480px;max-height:90vh;animation:slideUp .28s var(--ease);box-shadow:var(--shadow-xl);padding:26px;overflow-y:auto}.page-header{background:var(--bg-surface);border-bottom:1px solid var(--border-soft);z-index:100;padding:12px 16px;position:sticky;top:0}.header-main{justify-content:space-between!important;align-items:center!important;width:100%!important;min-height:auto!important;display:flex!important}.page-header h1{color:#1a1a1a!important;margin:0!important;font-size:20px!important;font-weight:700!important}.btn-draft-header{border:1px solid var(--border)!important;color:#1a1a1a!important;box-shadow:var(--shadow-xs)!important;cursor:pointer!important;background:#fff!important;border-radius:8px!important;align-items:center!important;gap:6px!important;padding:6px 12px!important;font-size:14px!important;font-weight:600!important;display:flex!important}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{letter-spacing:-.3px;color:var(--text-900);font-size:17px;font-weight:700}.modal-close{background:var(--bg-base);border:1px solid var(--border);color:var(--text-500);cursor:pointer;transition:var(--transition);border-radius:var(--r-xs);justify-content:center;align-items:center;width:30px;height:30px;padding:0;font-size:18px;display:flex}.modal-close:hover{background:var(--danger-bg);border-color:var(--danger);color:var(--danger)}.modal-body{flex-direction:column;gap:14px;display:flex}.modal-footer{border-top:1px solid var(--border-soft);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:18px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.loading{animation:1.6s infinite pulse}.empty-state{text-align:center;color:var(--text-300);padding:56px 20px}.empty-state .empty-icon{opacity:.25;margin-bottom:14px;font-size:44px}.empty-state p{font-size:13.5px}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.filter-bar input[type=date]{width:auto}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);animation:slideUp .28s var(--ease);box-shadow:var(--shadow-lg);align-items:center;gap:10px;min-width:260px;padding:12px 18px;font-size:13.5px;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--info)}@media print{body *{visibility:hidden}.print-area,.print-area *,.receipt-container *{visibility:visible!important}.print-area,.receipt-container{width:58mm;margin:0;padding:2mm;position:absolute;top:0;left:0}.kitchen-receipt{display:none!important}.client-receipt{display:block!important}body.print-kitchen .client-receipt{display:none!important}body.print-kitchen .kitchen-receipt{display:block!important}.receipt-preview{width:100%!important;box-shadow:none!important;border:none!important;padding:0!important}@page{size:58mm auto;margin:0}}@media (max-width:1024px){.pos-layout{flex-direction:column;gap:0;display:flex}.products-grid{max-height:50vh}.pos-cart{height:auto;max-height:none;min-height:unset}}@media (max-width:768px){input[type=text],input[type=number],input[type=search],input[type=date],input[type=password],select,textarea{font-size:16px}.sidebar-backdrop{-webkit-backdrop-filter:none;backdrop-filter:none;z-index:1040;opacity:0;visibility:hidden;background:0 0;width:100vw;height:100vh;position:fixed;top:0;left:0}.sidebar-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}.sidebar{transition:transform .3s var(--ease);box-shadow:var(--shadow-xl);padding-bottom:20px;transform:translate(-100%);z-index:1050!important;width:240px!important}.app-layout:not(.sidebar-collapsed) .sidebar{transform:translate(0)}.main-content{padding:12px 12px 100px;width:100%!important;margin-left:0!important}.mobile-toggle-btn{z-index:1050;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--r-sm);width:40px;height:40px;color:var(--text-700);cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease);justify-content:center;align-items:center;position:fixed;top:12px;left:12px;display:flex!important}.app-layout:not(.sidebar-collapsed) .mobile-toggle-btn{opacity:0;visibility:hidden;pointer-events:none}.mobile-toggle-btn:hover{background:var(--brand-dim);border-color:var(--brand);color:var(--brand)}.page-header{flex-direction:column;gap:0;min-height:44px;margin-bottom:8px;padding-left:60px;display:flex}.page-header h1{margin:0;font-size:18px;line-height:44px}.page-header .subtitle{margin-top:-8px;font-size:12px}.header-main{align-items:center;min-height:44px;display:flex}.btn-draft-header{flex:1;justify-content:center;margin-top:4px;padding:8px 4px;font-size:13px}.history-desktop-view{display:none}.history-mobile-view{flex-direction:column;gap:12px;display:flex}.history-card{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:16px}.history-card .card-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;display:flex}.history-card .trx-id{color:var(--text-900);font-weight:700;font-family:var(--font-mono)}.history-card .trx-time{color:var(--text-500);font-size:13px}.history-card .card-body{margin-bottom:16px}.history-card .trx-info{justify-content:space-between;align-items:flex-end;display:flex}.history-card .trx-total{color:var(--brand);font-size:18px;font-weight:800}.history-card .trx-date{color:var(--text-500);margin-top:4px;font-size:12px}.btn-reprint-mobile{border-radius:var(--r-sm);justify-content:center;align-items:center;gap:8px;width:100%;padding:12px;font-weight:600;display:flex}.products-grid{grid-template-columns:1fr;gap:8px;max-height:none;padding:10px 12px 180px}.product-card{text-align:left;flex-direction:row;align-items:center;gap:10px;padding:8px 12px}.product-initials{border-radius:10px;width:44px;height:44px;font-size:14px}.product-card .product-meta{justify-content:space-between;gap:10px}.cart-item{gap:8px;padding:9px 12px}.cart-item-info .item-name{font-size:12px}.cart-item-qty button{width:30px;height:30px}@media (max-width:480px){.cart-item{grid-template-columns:1fr auto auto;grid-template-areas:"info subtotal remove""qty actions actions";align-items:center;gap:12px 10px;padding:12px 16px;display:grid}.cart-item-info{grid-area:info}.cart-item-subtotal{grid-area:subtotal}.cart-item-remove{grid-area:remove}.cart-item-qty{grid-area:qty}.cart-item-actions-group{grid-area:actions;justify-content:flex-end}.cart-item-info .item-name{white-space:normal;text-overflow:clip;font-size:14px;overflow:visible}}.quick-cash{grid-template-columns:repeat(2,1fr)}.cart-footer{z-index:100;width:100%;padding:12px 14px calc(12px + env(safe-area-inset-bottom));background:var(--bg-surface);border-top:1px solid var(--border-soft);gap:8px;position:fixed;bottom:0;left:0;box-shadow:0 -8px 24px #1c181414}.cart-footer .btn{flex:1;padding:12px;font-size:13.5px}.cart-actions{flex-direction:column}}.laporan-stats-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.laporan-stat-value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;font-size:14px!important}.laporan-card-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.laporan-card-header h2{color:var(--text-900);letter-spacing:-.2px;flex-shrink:0;font-size:15px;font-weight:700}.laporan-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.laporan-controls input[type=date]{width:auto;min-width:140px}.laporan-desktop-view{display:block}.laporan-mobile-view{display:none}.laporan-trx-card{background:var(--bg-raised);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;transition:var(--transition);margin-bottom:10px;padding:14px}.laporan-trx-card:hover{border-color:var(--brand)}.laporan-trx-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.laporan-trx-id{color:var(--text-500);font-family:monospace;font-size:12px;font-weight:600}.laporan-trx-time{color:var(--text-500);margin-top:2px;font-size:12px}.laporan-trx-total{color:var(--brand);font-size:16px;font-weight:800}.laporan-trx-meta{color:var(--text-700);border-top:1px solid var(--border-soft);flex-wrap:wrap;gap:12px;padding-top:8px;font-size:12px;display:flex}.laporan-trx-detail{border-top:1px dashed var(--border);margin-top:10px;padding-top:10px}.laporan-trx-detail-row{color:var(--text-700);justify-content:space-between;padding:3px 0;font-size:12.5px;display:flex}.laporan-nav-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:16px 0 0;display:flex}.laporan-nav-buttons{flex-wrap:wrap;gap:8px;display:flex}.report-tabs .tab-btn:hover{color:var(--brand)!important;background:rgba(var(--brand-rgb),.05)!important}.report-tabs .tab-btn.active{box-shadow:0 2px 8px #00000014;background:var(--bg-surface)!important;color:var(--brand)!important}.date-range-group input[type=date]{border:1.5px solid var(--border);background:var(--bg-surface);color:var(--text-primary);border-radius:8px;padding:8px 12px;font-size:14px;transition:border-color .2s}.date-range-group input[type=date]:focus{border-color:var(--brand);outline:none}.table-container{border-radius:12px;overflow-x:auto}table tr:hover{background:rgba(var(--brand-rgb),.02)}@media (max-width:768px){.date-range-group{flex-direction:column;align-items:stretch!important}.date-range-group .btn{width:100%;margin-top:10px!important}.report-tabs{padding:6px!important}.tab-btn{padding:8px 4px!important;font-size:12px!important}}.produk-desktop-view{display:block}.produk-mobile-view{display:none}.produk-mobile-card{background:var(--bg-raised);border:1.5px solid var(--border);border-radius:var(--r);transition:var(--transition);margin-bottom:10px;padding:14px}.produk-mobile-card:hover{border-color:var(--brand);box-shadow:var(--shadow-sm)}.produk-mobile-card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.produk-mobile-card-actions{border-top:1px solid var(--border-soft);gap:8px;margin-top:10px;padding-top:10px;display:flex}@media (max-width:768px){.laporan-stats-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.stat-card{padding:12px}.stat-card .stat-icon{width:32px;height:32px;margin-bottom:8px;font-size:14px}.stat-card .stat-value{letter-spacing:0;font-size:13px!important}.stat-card .stat-label{font-size:10px}.laporan-stat-value{font-size:12px!important}.laporan-card-header{flex-direction:column;align-items:flex-start;gap:10px}.laporan-controls{width:100%}.laporan-controls input[type=date]{flex:1;min-width:0}.laporan-controls .btn{flex:1;padding:8px 10px;font-size:12px}.laporan-desktop-view{display:none}.laporan-mobile-view{display:block}.laporan-nav-footer{flex-direction:column;align-items:stretch}.laporan-nav-buttons{flex-direction:row;justify-content:space-between}.laporan-nav-buttons .btn{text-align:center;flex:1;padding:8px 4px;font-size:11.5px}.produk-desktop-view{display:none}.produk-mobile-view{display:block}.pengaturan-card{width:100%!important;max-width:100%!important}}.cart-item-wrap{border-bottom:1px solid var(--border-soft)}.cart-item-wrap:last-child{border-bottom:none}.cart-item-action-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:16px;transition:opacity .15s,background .15s}.cart-item-action-btn:hover{opacity:1;background:var(--bg-primary)}.diskon-badge{background:var(--danger-bg,#fef2f2);color:var(--danger,#ef4444);border:1px solid var(--danger,#ef4444);vertical-align:middle;border-radius:4px;margin-left:6px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-block}.item-catatan{color:var(--text-muted,#9ca3af);margin-top:2px;font-size:11px;font-style:italic}.item-edit-form{background:var(--bg-primary,#f5f5f5);border-top:1px dashed var(--border);border-radius:0 0 8px 8px;flex-direction:column;gap:8px;padding:12px 14px;animation:.2s slideUp;display:flex}.item-edit-row{align-items:center;gap:10px;display:flex}.item-edit-row label{color:var(--text-muted);min-width:80px;font-size:12px;font-weight:600}.item-edit-row input[type=number]{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);border-radius:6px;padding:6px 10px;font-size:14px}.tipe-diskon-btn{border:1.5px solid var(--border);background:var(--bg-surface);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:13px;font-weight:600;transition:all .15s}.tipe-diskon-btn.active{background:var(--accent-primary,#6366f1);border-color:var(--accent-primary,#6366f1);color:#fff}.item-note-wrap{background:var(--bg-primary);border-top:1px dashed var(--border);border-radius:0 0 8px 8px;align-items:center;gap:8px;padding:8px 14px;animation:.2s slideUp;display:flex}.item-note-input{border:1px solid var(--border);background:var(--bg-surface);color:var(--text-primary);border-radius:6px;flex:1;padding:7px 10px;font-size:14px}.item-note-input:focus{border-color:var(--accent-primary,#6366f1);outline:none;box-shadow:0 0 0 2px #6366f126}.laporan-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1200;background:#00000073;justify-content:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.laporan-drawer{background:var(--bg-surface);width:100%;max-width:420px;height:100%;animation:slideDrawer .28s var(--ease,ease);flex-direction:column;display:flex;box-shadow:-8px 0 32px #0003}@keyframes slideDrawer{0%{transform:translate(100%)}to{transform:translate(0)}}.laporan-drawer-header{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.laporan-drawer-header h2{color:var(--text-900,var(--text-primary));margin:0 0 2px;font-size:18px;font-weight:700}.laporan-drawer-stats{border-bottom:1px solid var(--border-soft);grid-template-columns:1fr 1fr;gap:12px;padding:16px;display:grid}.laporan-stat-box{background:var(--bg-primary);border:1px solid var(--border-soft);border-radius:10px;padding:12px 14px}.laporan-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:11px;font-weight:600}.laporan-stat-value{font-size:18px;font-weight:800}.laporan-stat-value.green{color:var(--success,#10b981)}.laporan-stat-value.blue{color:var(--accent-primary,#6366f1)}.laporan-drawer-body{flex:1;padding:8px 0;overflow-y:auto}.laporan-trx-row{border-bottom:1px solid var(--border-soft);cursor:pointer;padding:14px 18px;transition:background .15s}.laporan-trx-row:hover{background:var(--bg-raised,var(--bg-primary))}.laporan-trx-row-main{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.laporan-trx-row-id{color:var(--text-muted);font-family:monospace;font-size:11px;font-weight:600}.laporan-trx-row-detail{border-top:1px dashed var(--border);margin-top:10px;padding-top:10px;font-size:13px}.laporan-drawer-footer{border-top:1px solid var(--border-soft);background:var(--bg-surface);padding:14px 16px}@media (max-width:480px){.laporan-drawer{max-width:100%}}.nota-preview{border:1px dashed var(--border);color:#222;background:#fff;border-radius:8px;max-width:300px;margin-bottom:20px;margin-left:auto;margin-right:auto;padding:14px;font-family:Courier New,Courier,monospace;font-size:12px}.nota-preview-section{padding:8px 0;position:relative}.nota-preview-label{letter-spacing:.08em;text-transform:uppercase;border-radius:3px;margin-bottom:6px;padding:2px 6px;font-family:Inter,sans-serif;font-size:9px;font-weight:800;display:inline-block}.header-section .nota-preview-label{color:#1d4ed8;background:#dbeafe}.footer-section .nota-preview-label{color:#15803d;background:#dcfce7}.nota-preview-content{line-height:1.5}.nota-preview-custom{color:#555;white-space:pre-line;border-top:1px dotted #ccc;margin-top:4px;padding-top:4px;font-size:11px;font-style:italic}.nota-preview-divider{text-align:center;color:#bbb;letter-spacing:1px;padding:4px 0;font-size:11px}.compact-kasir-header{height:56px;max-height:64px;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;gap:8px!important;padding-top:4px!important;padding-bottom:4px!important;display:flex!important}.kasir-header-title{flex:1;align-items:center;display:flex}.kasir-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-header-pill{cursor:pointer;white-space:nowrap;border:1.5px solid #0000;border-radius:30px;align-items:center;gap:7px;padding:8px 16px;font-size:13px;font-weight:700;transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.btn-header-pill:active{transform:scale(.97)}.btn-header-pill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff73,#0000);width:60%;height:200%;transition:all .5s;position:absolute;top:-50%;left:-120%;transform:rotate(30deg)}.btn-header-pill:hover:after{left:140%}.btn-header-pill.sales{color:#1d4ed8;background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border-color:#93c5fd}.btn-header-pill.sales:hover{background:linear-gradient(135deg,#bfdbfe 0%,#93c5fd 100%);border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 6px 20px #3b82f64d}.btn-header-pill.sales .pill-icon{filter:drop-shadow(0 1px 2px #1d4ed84d);font-size:16px}.btn-header-pill.draft{color:#92400e;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-color:#fcd34d}.btn-header-pill.draft:hover{background:linear-gradient(135deg,#fde68a 0%,#fcd34d 100%);border-color:#f59e0b;transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b4d}.btn-header-pill.draft .pill-icon{filter:drop-shadow(0 1px 2px #92400e4d);font-size:16px}.pill-badge{color:#fff;background:#b45309;border-radius:20px;margin-left:2px;padding:1px 7px;font-size:11px;font-weight:800;box-shadow:0 1px 4px #b4530966}.pill-text{align-items:center;gap:4px;display:flex}@media (max-width:400px){.compact-kasir-header{gap:4px!important;padding-left:8px!important;padding-right:8px!important}.compact-kasir-header h1{font-size:16px!important}.btn-header-pill{gap:5px;padding:6px 10px;font-size:12px}}@media (max-width:320px){.pill-text span:not(.pill-badge){display:none}.btn-header-pill{padding:7px 10px}}.draft-detail-view .preview-items::-webkit-scrollbar{width:4px}.draft-detail-view .preview-items::-webkit-scrollbar-thumb{background:var(--border-soft);border-radius:4px}.lp-period-tabs{gap:8px;margin-bottom:12px;display:flex}.lp-period-pill{border-radius:var(--r-sm);border:1.5px solid var(--border);background:var(--bg-surface);color:var(--text-500);cursor:pointer;transition:var(--transition);text-align:center;white-space:nowrap;flex:1;padding:10px 6px;font-family:inherit;font-size:13px;font-weight:600}.lp-period-pill:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-dim)}.lp-period-pill.active{background:var(--brand-gradient);color:#fff;box-shadow:var(--brand-glow);border-color:#0000}.lp-filter-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);margin-bottom:14px;padding:14px 16px}.lp-filter-row{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.lp-filter-group{flex-direction:column;flex:1;gap:4px;min-width:120px;display:flex}.lp-filter-label{color:var(--text-500);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:700}.lp-filter-input{border:1.5px solid var(--border);border-radius:var(--r-sm);background:var(--bg-base);color:var(--text-900);transition:var(--transition);outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:14px}.lp-filter-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-dim);background:#fff}.lp-export-btn{background:var(--success);color:#fff;border-radius:var(--r-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:6px;height:40px;padding:9px 18px;font-family:inherit;font-size:13.5px;font-weight:700;display:inline-flex;box-shadow:0 3px 10px #3a8c5c40}.lp-export-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #3a8c5c59}.lp-export-btn:disabled{opacity:.5;cursor:not-allowed}.lp-stats-row{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;display:grid}.lp-stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);transition:var(--transition);align-items:center;gap:8px;min-width:0;padding:12px 10px;display:flex;position:relative;overflow:hidden}.lp-stat-card:before{content:"";border-radius:var(--r)var(--r)0 0;height:3px;position:absolute;top:0;left:0;right:0}.lp-stat-card.green:before{background:var(--success)}.lp-stat-card.blue:before{background:var(--info)}.lp-stat-card.amber:before{background:var(--warning)}.lp-stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.lp-stat-icon{flex-shrink:0;font-size:18px;line-height:1}.lp-stat-body{flex:1;min-width:0}.lp-stat-value{color:var(--text-900);letter-spacing:-.3px;overflow-wrap:anywhere;word-break:break-all;font-size:13px;font-weight:800;line-height:1.2}.lp-stat-label{color:var(--text-500);white-space:nowrap;margin-top:2px;font-size:10.5px;font-weight:500}.lp-view-tabs{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);margin-bottom:14px;padding:4px;display:flex}.lp-view-tab{color:var(--text-300);cursor:pointer;transition:var(--transition);text-align:center;background:0 0;border:none;border-radius:10px;flex:1;padding:9px 4px;font-family:inherit;font-size:12.5px;font-weight:600}.lp-view-tab:hover{color:var(--text-700);background:var(--bg-base)}.lp-view-tab.active{background:var(--brand-dim);color:var(--brand);box-shadow:var(--shadow-xs)}.lp-loading{color:var(--text-300);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;font-size:13.5px;display:flex}.lp-spinner{vertical-align:middle;border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite lp-spin;display:inline-block}.lp-spinner.large{border-width:3px;border-color:var(--border);border-top-color:var(--brand);width:32px;height:32px}@keyframes lp-spin{to{transform:rotate(360deg)}}.lp-empty{color:var(--text-300);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:60px 20px;display:flex}.lp-empty-icon{opacity:.4;font-size:44px}.lp-empty p{font-size:14px;font-weight:500}.lp-content{flex-direction:column;display:flex}.lp-annual-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.lp-annual-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-xs);padding:14px}.lp-annual-card:hover{border-color:var(--brand);background:var(--brand-dim);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.lp-annual-card:hover .lp-annual-arrow{color:var(--brand);transform:translate(3px)}.lp-annual-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:10px;display:flex}.lp-annual-month{color:var(--text-900);font-size:13px;font-weight:700}.lp-annual-count{color:var(--text-500);margin-top:2px;font-size:11px}.lp-annual-arrow{color:var(--text-300);transition:var(--transition);font-size:18px;line-height:1}.lp-annual-bar-wrap{background:var(--border-soft);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.lp-annual-bar{background:var(--brand-gradient);height:100%;transition:width .6s var(--ease);border-radius:2px}.lp-annual-total{color:var(--success);letter-spacing:-.3px;font-size:13px;font-weight:800}.lp-daily-list{flex-direction:column;gap:8px;display:flex}.lp-daily-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-xs);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.lp-daily-card:hover{border-color:var(--brand);background:var(--brand-dim);transform:translate(2px)}.lp-daily-left{flex:1;align-items:center;gap:14px;min-width:0;display:flex}.lp-daily-date-box{background:var(--brand-dim);border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:46px;display:flex}.lp-daily-dd{color:var(--brand);font-size:18px;font-weight:800;line-height:1}.lp-daily-mmm{color:var(--brand-light);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.lp-daily-title{color:var(--text-900);font-size:14px;font-weight:700}.lp-daily-count{color:var(--text-500);margin-top:2px;font-size:12px}.lp-daily-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.lp-daily-total{color:var(--success);font-size:14px;font-weight:800}.lp-daily-chevron{color:var(--text-300);font-size:20px;line-height:1}.lp-trx-list{flex-direction:column;gap:8px;display:flex}.lp-trx-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);transition:border-color .2s;overflow:hidden}.lp-trx-card.expanded{border-color:var(--brand)}.lp-trx-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:12px;padding:14px 16px;transition:background .15s;display:flex}.lp-trx-header:hover{background:var(--bg-raised)}.lp-trx-left{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.lp-trx-avatar{background:var(--brand-dim);width:38px;height:38px;color:var(--brand);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;font-weight:800;display:flex}.lp-trx-info{flex:1;min-width:0}.lp-trx-name{color:var(--text-900);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.lp-trx-meta{color:var(--text-500);flex-wrap:wrap;align-items:center;gap:5px;margin-top:3px;font-size:12px;display:flex}.lp-dot{opacity:.4}.lp-method-badge{text-transform:capitalize;border-radius:20px;align-items:center;gap:3px;padding:2px 7px;font-size:10.5px;font-weight:600;display:inline-flex}.lp-method-badge.tunai{background:var(--success-bg);color:var(--success)}.lp-method-badge.transfer{background:var(--info-bg);color:var(--info)}.lp-trx-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.lp-trx-total{color:var(--success);letter-spacing:-.3px;font-size:14px;font-weight:800}.lp-trx-chevron{color:var(--text-300);font-size:10px}.lp-trx-detail{border-top:1px solid var(--border-soft);background:var(--bg-raised);flex-direction:column;gap:8px;padding:12px 16px 14px;display:flex}.lp-trx-detail-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-300);margin-bottom:2px;font-size:10px;font-weight:700}.lp-trx-item-row{justify-content:space-between;align-items:center;gap:8px;font-size:13.5px;display:flex}.lp-trx-item-name{color:var(--text-700);flex:1;min-width:0}.lp-trx-qty{color:var(--brand);font-weight:700}.lp-trx-item-sub{color:var(--success);flex-shrink:0;font-weight:700}.lp-delete-btn{background:var(--danger-bg);width:100%;color:var(--danger);border-radius:var(--r-sm);cursor:pointer;transition:var(--transition);border:1px solid #c4404033;margin-top:4px;padding:9px;font-family:inherit;font-size:12.5px;font-weight:600}.lp-delete-btn:hover{background:var(--danger);color:#fff}.lp-rank-list{flex-direction:column;gap:8px;display:flex}.lp-rank-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);transition:var(--transition);align-items:center;gap:12px;padding:14px 16px;display:flex}.lp-rank-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border-strong)}.lp-rank-num{border-radius:var(--r-sm);width:34px;height:34px;font-size:12px;font-weight:800;font-family:var(--font-mono);color:var(--text-500);background:var(--bg-base);flex-shrink:0;justify-content:center;align-items:center;display:flex}.lp-rank-num.top{background:0 0;font-size:18px}.lp-rank-info{flex:1;min-width:0}.lp-rank-name{color:var(--text-900);white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:700;overflow:hidden}.lp-rank-sub{color:var(--text-500);align-items:center;gap:8px;margin-top:3px;font-size:12px;display:flex}.lp-category-badge{background:var(--info-bg);color:var(--info);border-radius:20px;padding:2px 7px;font-size:10.5px;font-weight:600;display:inline-block}.lp-rank-bar-wrap{background:var(--border-soft);border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.lp-rank-bar{background:linear-gradient(90deg,var(--info)0%,var(--brand)100%);height:100%;transition:width .6s var(--ease);border-radius:2px}.lp-rank-total{color:var(--success);text-align:right;flex-shrink:0;font-size:14px;font-weight:800}.lp-cat-list{flex-direction:column;gap:8px;display:flex}.lp-cat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-xs);transition:var(--transition);padding:14px 16px}.lp-cat-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border-strong)}.lp-cat-top{justify-content:space-between;align-items:flex-start;margin-bottom:10px;display:flex}.lp-cat-name{color:var(--text-900);font-size:14px;font-weight:700}.lp-cat-sub{color:var(--text-500);margin-top:2px;font-size:12px}.lp-cat-total{color:var(--success);text-align:right;font-size:14px;font-weight:800}.lp-cat-pct{color:var(--text-300);text-align:right;margin-top:2px;font-size:11px}.lp-cat-bar-track{background:var(--border-soft);border-radius:3px;height:6px;overflow:hidden}.lp-cat-bar-fill{background:var(--brand-gradient);height:100%;transition:width .6s var(--ease);border-radius:3px}.lp-modal-dialog{z-index:1500;background:0 0;border:none;border-radius:0;justify-content:center;align-items:flex-end;width:100%;max-width:100%;margin:0;padding:0;position:fixed;inset:0}dialog[open].lp-modal-dialog{display:flex}.lp-modal-dialog::backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080}.lp-modal-box{background:var(--bg-surface);border-radius:var(--r-xl)var(--r-xl)0 0;width:100%;max-width:600px;max-height:88vh;box-shadow:var(--shadow-xl);animation:lp-slideup .28s var(--ease);flex-direction:column;display:flex;overflow:hidden}@keyframes lp-slideup{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.lp-modal-header{border-bottom:1px solid var(--border-soft);background:var(--bg-raised);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.lp-modal-eyebrow{text-transform:uppercase;letter-spacing:.8px;color:var(--text-300);margin-bottom:4px;font-size:10px;font-weight:700}.lp-modal-title{color:var(--brand);letter-spacing:-.3px;font-size:17px;font-weight:800}.lp-modal-header-right{align-items:center;gap:14px;display:flex}.lp-modal-summary{text-align:right}.lp-modal-summary-count{color:var(--text-500);font-size:11px;display:block}.lp-modal-summary-total{color:var(--success);font-size:15px;font-weight:800;display:block}.lp-modal-close{border:1.5px solid var(--border);background:var(--bg-base);width:34px;height:34px;color:var(--text-500);cursor:pointer;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex}.lp-modal-close:hover{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.lp-modal-body{flex:1;padding:14px 16px;overflow-y:auto}.lp-modal-footer{border-top:1px solid var(--border-soft);background:var(--bg-raised);padding:14px 16px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));flex-shrink:0}.lp-modal-close-btn{background:var(--brand-gradient);color:#fff;border-radius:var(--r-sm);cursor:pointer;width:100%;box-shadow:var(--brand-glow);transition:var(--transition);border:none;padding:12px;font-family:inherit;font-size:14px;font-weight:700}.lp-modal-close-btn:hover{opacity:.9}.lp-modal-backdrop{z-index:-1;position:fixed;inset:0}.lp-modal-backdrop button{opacity:0;cursor:default;background:0 0;border:none;width:100%;height:100%}@media (min-width:768px){.lp-period-tabs{max-width:420px}.lp-annual-grid{grid-template-columns:repeat(4,1fr);gap:12px}.lp-stat-value{font-size:15px}.lp-stat-card{gap:10px;padding:14px 12px}.lp-stat-icon{font-size:20px}.lp-view-tab{font-size:13.5px}.lp-annual-month{font-size:14px}.lp-modal-dialog{align-items:center}.lp-modal-box{border-radius:var(--r-xl);max-height:80vh;animation:lp-fadeup .25s var(--ease);margin:auto}@keyframes lp-fadeup{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}}@media (max-width:400px){.lp-stat-card{gap:6px;padding:8px 6px}.lp-stat-icon{font-size:15px}.lp-stat-value{letter-spacing:-.2px;font-size:11px}.lp-stat-label{font-size:9.5px}.lp-annual-grid{grid-template-columns:repeat(2,1fr)}.lp-period-pill{padding:9px 4px;font-size:12px}}
