.ecash-wrapper{padding:2.5rem 1.5rem;max-width:1400px;margin:0 auto;min-height:calc(100vh - 70px)}.ecash-header{margin-bottom:2rem}.ecash-header h1{font-size:2.5rem;font-weight:800;margin:0}.ecash-header p{color:var(--text-muted);margin-top:.25rem;font-size:1.1rem}.ecash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem}.ecash-stat{padding:1.5rem;border-radius:1.5rem;position:relative;overflow:hidden}.ecash-stat .stat-lbl{font-size:.75rem;font-weight:700;text-transform:uppercase;opacity:.85}.ecash-stat .stat-val{font-size:1.75rem;font-weight:900;margin-top:.25rem}.ecash-stat .stat-sub{font-size:.75rem;opacity:.7;margin-top:.25rem}.ecash-stat .stat-bg{position:absolute;right:-10px;bottom:-10px;font-size:4rem;opacity:.1}.stat-wallet{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.stat-cash{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.stat-in{background:#3b82f61a;color:#3b82f6}.stat-out{background:#f973161a;color:#f97316}.stat-earn{background:#8b5cf61a;color:#8b5cf6}.ecash-actions{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.ecash-btn{padding:1rem 2rem;border-radius:1.25rem;font-weight:800;font-size:1rem;cursor:pointer;border:none;transition:all .2s;display:flex;align-items:center;gap:.5rem}.ecash-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.ecash-btn:active{transform:scale(.97)}.btn-cashin{background:#3b82f6;color:#fff}.btn-cashout{background:#f97316;color:#fff}.btn-adjust{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.ecash-history{margin-top:1rem}.ecash-history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:1rem}.ecash-history-header h2{font-size:1.4rem;font-weight:800;margin:0}.ecash-date-pick{background:var(--surface-hover);border:1px solid var(--border);border-radius:.75rem;padding:.5rem .75rem;font-weight:700;color:var(--text);font-size:.85rem}.ecash-list{display:flex;flex-direction:column;gap:.75rem}.ecash-tx{background:var(--surface);border:1px solid var(--border);border-radius:1.25rem;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.ecash-tx:hover{border-color:var(--primary);transform:translate(4px)}.ecash-tx .tx-type{padding:.3rem .75rem;border-radius:.5rem;font-size:.7rem;font-weight:800;text-transform:uppercase;flex-shrink:0}.tx-type.in{background:#3b82f626;color:#3b82f6}.tx-type.out{background:#f9731626;color:#f97316}.ecash-tx .tx-info{flex:1;min-width:0}.ecash-tx .tx-info .tx-name{font-weight:700;font-size:.95rem}.ecash-tx .tx-info .tx-meta{font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.ecash-tx .tx-amounts{text-align:right;flex-shrink:0}.ecash-tx .tx-amounts .tx-amt{font-weight:900;font-size:1.15rem}.ecash-tx .tx-amounts .tx-fee{font-size:.75rem;color:var(--text-muted)}.ecash-tx .tx-receipt-thumb{width:40px;height:40px;border-radius:.5rem;object-fit:cover;cursor:pointer;border:1px solid var(--border);flex-shrink:0}.ecash-tx .tx-del{background:none;border:none;color:var(--danger);cursor:pointer;font-size:1.25rem;opacity:.4;padding:.25rem}.ecash-tx .tx-del:hover{opacity:1}.ecash-empty{text-align:center;padding:4rem;background:var(--surface-hover);border-radius:1.5rem;border:2px dashed var(--border);color:var(--text-muted)}.ecash-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ae6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ecash-modal{width:100%;max-width:480px;background:var(--surface);border-radius:1.5rem;padding:2rem;animation:ecashSlideUp .3s ease-out;max-height:90vh;overflow-y:auto}.ecash-modal h2{font-size:1.5rem;font-weight:800;margin:0 0 .25rem}.ecash-modal .modal-sub{color:var(--text-muted);margin-bottom:1.5rem;font-size:.9rem}.ecash-modal .fg{margin-bottom:1.25rem}.ecash-modal .fg label{display:block;font-size:.8rem;font-weight:700;color:var(--text-muted);margin-bottom:.4rem}.ecash-modal .fg input,.ecash-modal .fg select{width:100%;padding:.75rem 1rem;border-radius:.75rem;border:1px solid var(--border);background:var(--surface-hover);color:var(--text);font-size:.95rem;font-weight:600}.ecash-modal .fg-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.ecash-modal .modal-btns{display:flex;gap:1rem;margin-top:1.5rem}.ecash-modal .modal-btns button{flex:1;padding:.9rem;border-radius:.75rem;font-weight:800;font-size:.95rem;cursor:pointer;border:none}.receipt-preview{margin-top:.75rem;position:relative;display:inline-block}.receipt-preview img{width:100%;max-height:200px;object-fit:contain;border-radius:.75rem;border:1px solid var(--border)}.receipt-preview .remove-receipt{position:absolute;top:4px;right:4px;background:#000000b3;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:.8rem}.receipt-actions{display:flex;gap:.75rem;margin-top:.5rem}.receipt-actions button{padding:.6rem 1rem;border-radius:.75rem;font-weight:700;font-size:.8rem;cursor:pointer;border:1px solid var(--border);background:var(--surface-hover);color:var(--text);flex:1}.receipt-actions .scan-btn{background:var(--primary);color:#fff;border-color:var(--primary)}.receipt-viewer{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.receipt-viewer img{max-width:100%;max-height:85vh;border-radius:.75rem}.receipt-viewer .close-viewer{position:absolute;top:1rem;right:1rem;background:#fff3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.25rem;cursor:pointer}.ocr-loading{display:flex;align-items:center;gap:.5rem;padding:.5rem;color:var(--primary);font-size:.85rem;font-weight:700}@keyframes ecashSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.ecash-wrapper{padding:1.5rem 1rem 100px}.ecash-header h1{font-size:2rem}.ecash-actions{flex-direction:column}.ecash-btn{justify-content:center}.ecash-tx{flex-wrap:wrap}.stat-val{font-size:1.4rem!important}}@media (max-width: 480px){.ecash-stats{grid-template-columns:1fr 1fr}.ecash-modal .fg-row{grid-template-columns:1fr}}:root{--radius: .75rem;--radius-lg: 1.25rem;--radius-xl: 2rem;--safe-area-bottom: env(safe-area-inset-bottom, 0px);--primary-rgb: 99, 102, 241}[data-theme=dark]{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: rgba(99, 102, 241, .1);--background: #0f172a;--surface: #1e293b;--surface-hover: #334155;--text: #f8fafc;--text-muted: #94a3b8;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--border: rgba(255, 255, 255, .1)}[data-theme=light]{--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: rgba(79, 70, 229, .05);--background: #f8fafc;--surface: #ffffff;--surface-hover: #f1f5f9;--text: #0f172a;--text-muted: #64748b;--danger: #ef4444;--success: #10b981;--warning: #f59e0b;--border: #e2e8f0}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{font-family:Outfit,Inter,-apple-system,sans-serif;background-color:var(--background);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s ease,color .3s ease;overflow-x:hidden;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:800;line-height:1.2}button{cursor:pointer;font-family:inherit;color:inherit;transition:all .25s cubic-bezier(.4,0,.2,1);border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--primary);color:#fff!important;padding:.8rem 1.6rem;border-radius:var(--radius);font-weight:700;box-shadow:0 4px 14px rgba(var(--primary-rgb),.3)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--primary-rgb),.2)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--surface);color:var(--text);padding:.8rem 1.6rem;border:1px solid var(--border);border-radius:var(--radius);font-weight:700}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--primary)}.input-field{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.85rem 1.2rem;border-radius:var(--radius);width:100%;font-size:1rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1)}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.card{background:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:800;text-transform:uppercase}.badge-success{background:#10b9811a;color:#10b981}.badge-danger{background:#ef44441a;color:#ef4444}.badge-warning{background:#f59e0b1a;color:#f59e0b}.animate-fade-in{animation:fadeIn .4s ease-out}.animate-slide-up{animation:slideUp .5s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:.75rem .5rem calc(.75rem + var(--safe-area-bottom));z-index:1000;box-shadow:0 -4px 15px #0000001a}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;background:none;border:none;color:var(--text-muted);font-size:.7rem;font-weight:700;transition:.2s;flex:1}.bottom-nav-item.active{color:var(--primary)}.bottom-nav-icon{font-size:1.5rem}@media (max-width: 768px){:root{--radius: 1rem;--radius-lg: 1.5rem}body{padding-bottom:calc(85px + var(--safe-area-bottom));font-size:16px}.card{padding:1.25rem}.btn-primary,.btn-secondary{padding:1rem;width:100%}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media print{body *{visibility:hidden}#receipt-print-area,#receipt-print-area *{visibility:visible}#receipt-print-area{display:block!important;position:absolute;left:0;top:0;width:80mm;margin:0;padding:10mm;background:#fff!important;color:#000!important;font-family:Courier New,Courier,monospace!important;font-size:12pt;line-height:1.2}.print-only{display:block!important}.no-print{display:none!important}}.receipt-container{font-family:Courier New,Courier,monospace;color:#000;background:#fff;padding:2.5rem;width:100%;max-width:350px;margin:0 auto;border:1px dashed #ccc;text-align:center}.r-header{font-weight:700;font-size:1.25rem;margin-bottom:5px;text-transform:uppercase}.r-text{margin-bottom:5px;font-size:.85rem;line-height:1.4}.r-line{border-top:1px dashed black;margin:12px 0;width:100%}.r-item,.r-total{display:flex;justify-content:space-between;width:100%;margin-bottom:5px;font-size:.9rem}.r-total{font-weight:700;font-size:1.15rem;margin:10px 0}.r-footer{text-align:center;margin-top:15px;font-size:.85rem}@media print{@page{margin:0}body *{visibility:hidden}#receipt-print-area,#receipt-print-area *{visibility:visible}#receipt-print-area{position:absolute;left:0;top:0;width:58mm;padding:2mm;margin:0;display:block!important}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;justify-content:center;align-items:center;z-index:10000;transition:all .3s ease}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.7}to{transform:scale(1);opacity:1}}.typing{display:flex!important;gap:6px!important;padding:1rem 1.5rem!important;align-items:center!important}.typing span{width:10px;height:10px;background:var(--primary);border-radius:50%;animation:thinking-bounce 1.4s infinite ease-in-out both;opacity:.7}.typing span:nth-child(1){animation-delay:-.32s}.typing span:nth-child(2){animation-delay:-.16s}@keyframes thinking-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}
