.dashboard-header-shared{background-color:#fff;color:#111827;padding:1rem;box-shadow:0 2px 4px #0000000f;width:100%;box-sizing:border-box;position:relative;z-index:40}.dashboard-header-content{max-width:600px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:1rem;box-sizing:border-box}.dashboard-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.dashboard-header-logo{height:60px;width:auto;object-fit:contain;display:block;flex-shrink:0}.dashboard-header-text{display:flex;flex-direction:column;gap:2px;min-width:0}.dashboard-header-title{font-size:1rem;font-weight:700;color:#111827;line-height:1;margin:0;word-break:break-word}.dashboard-header-subtitle{font-size:.8rem;color:#6b7280;line-height:1;margin:0}.dashboard-header-user{font-size:.75rem;color:#9ca3af;line-height:1;margin:0}.dashboard-header-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.dashboard-header-action-btn{background:transparent;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-size:1.2rem;transition:background-color .2s,transform .12s;display:flex;align-items:center;justify-content:center;line-height:0;color:#222c6e}.dashboard-header-action-btn:hover{background-color:#0000000f;transform:translateY(-1px)}.dashboard-header-logout-btn{background:transparent;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-size:1.2rem;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:0;color:#222c6e}.dashboard-header-logout-btn:hover{background-color:#0000000f}@media (max-width: 480px){.dashboard-header-content{max-width:100%;flex-wrap:wrap}.dashboard-header-title{font-size:.9rem}.dashboard-header-user{display:none}}@media (min-width: 1024px){.dashboard-header-shared{padding:1.5rem 2rem}.dashboard-header-content{max-width:100%;margin:0}.dashboard-header-title{font-size:1.2rem;font-weight:700}.dashboard-header-subtitle{font-size:.9rem}.dashboard-header-user{font-size:.85rem;display:block}.dashboard-header-right{gap:1rem}.dashboard-header-logo{height:80px;width:auto}.dashboard-header-action-btn,.dashboard-header-logout-btn{padding:.75rem;font-size:1.4rem}}.dashboard-footer{text-align:center;padding:.75rem 1rem;background:transparent;width:100%;box-sizing:border-box;margin-top:1.5rem}.dashboard-footer-event{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;box-sizing:border-box}.dashboard-footer-logo{width:60px;max-width:30%;height:auto;display:block}.dashboard-footer-eventName{font-size:.95rem;color:#374151;font-weight:600}.dashboard-footer-copyright{font-size:.7rem;color:#a8a8a8;text-align:center;margin-top:.5rem;opacity:.7}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr!important}.batch-actions{flex-direction:column;align-items:stretch!important}.action-buttons{width:100%;justify-content:stretch}.action-buttons button{flex:1}.collections-list,.submissions-list{grid-template-columns:1fr!important}.modal{margin:1rem}}@media (max-width: 480px){.stat-value{font-size:1.25rem!important}.stat-icon{font-size:1.5rem!important}.card-amount{font-size:1rem!important}}.action-button:hover{background:#f3f4f6;border-color:#9ca3af}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.collection-card:hover{box-shadow:0 4px 12px #0000001a}.expand-button:hover{background:#f3f4f6;border-color:#9ca3af}.submit-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}input:focus,textarea:focus,select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.fm-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.fm-container{min-height:100vh;background-color:#f3f4f6;display:flex;flex-direction:column;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.fm-header{background-color:#fff;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d}.fm-header-left{display:flex;flex-direction:column;gap:.25rem}.fm-title{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.fm-welcome-text{font-size:.875rem;color:#6b7280;margin:0}.fm-header-right{display:flex;align-items:center;gap:1.5rem}.fm-date{font-size:.875rem;color:#6b7280}.fm-logout-button{padding:.5rem 1rem;background-color:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.fm-logout-button:hover{background-color:#fecaca}.fm-tab-nav{background-color:#fff;padding:0 2rem;display:flex;gap:2rem;border-bottom:1px solid #e5e7eb}.fm-tab-button{padding:1rem .5rem;background:none;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s}.fm-tab-button-active{color:#3b82f6;border-bottom-color:#3b82f6}.fm-tab-icon{font-size:1.1rem}.fm-badge{background-color:#ef4444;color:#fff;font-size:.75rem;padding:.1rem .4rem;border-radius:9999px;margin-left:.25rem}.fm-content{flex:1;padding:2rem;width:100%;max-width:100%;overflow-x:hidden}.fm-content .collection-overview,.fm-content .collection-history{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:20px;overflow-x:auto}.collection-overview .table-container,.collection-history .table-container{min-width:0;width:100%}.fm-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:#f3f4f6}.fm-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;background-color:#f3f4f6}.fm-error-message{color:#dc2626;font-size:1.1rem;margin-bottom:1rem}.fm-button{padding:.5rem 1rem;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer}.pin-dialog{background:#fff;border-radius:16px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.pin-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:2px solid #f3f4f6}.pin-dialog-header h3{font-size:20px;font-weight:700;color:#1f2937;margin:0;display:flex;align-items:center;gap:8px}.close-button{background:none;border:none;font-size:24px;color:#9ca3af;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#6b7280}.submission-summary{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;padding:16px;border-left:4px solid #3b82f6}.summary-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 0;border-bottom:1px solid #bfdbfe}.summary-row:last-child{border-bottom:none}.summary-label{font-size:14px;color:#1e40af;font-weight:500}.summary-value{font-size:14px;color:#1e3a8a;font-weight:600;text-align:right;max-width:60%;word-break:break-word}.summary-value.amount{font-size:20px;color:#10b981;font-weight:700}.pin-label{font-size:15px;font-weight:600;color:#374151;display:flex;align-items:center;gap:6px}.pin-input{width:100%;padding:14px 16px;font-size:18px;border:2px solid #d1d5db;border-radius:8px;text-align:center;letter-spacing:8px;font-weight:600;transition:all .2s}.pin-input.error{border-color:#ef4444}.pin-input:disabled{background:#f3f4f6;cursor:not-allowed}.pin-dot{width:14px;height:14px;border-radius:50%;background:#e5e7eb;transition:all .2s}.pin-dot.filled{background:linear-gradient(135deg,#667eea,#764ba2);transform:scale(1.1)}.error-message{color:#ef4444;font-size:13px;margin-top:4px;font-weight:500;display:flex;align-items:center;gap:4px}.error-message:before{content:"⚠️"}.note-label{font-size:14px;font-weight:600;color:#374151}.note-textarea{width:100%;padding:12px;font-size:14px;border:2px solid #d1d5db;border-radius:8px;font-family:inherit;resize:vertical;min-height:80px;transition:all .2s}.note-textarea:disabled{background:#f3f4f6;cursor:not-allowed}.char-count{text-align:right;font-size:12px;color:#9ca3af}.security-tip{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#fef3c7;border-left:4px solid #f59e0b;border-radius:8px}.tip-icon{font-size:18px;flex-shrink:0}.tip-text{font-size:13px;color:#92400e;line-height:1.5;font-weight:500}.pin-dialog-footer{display:flex;gap:12px;padding:20px 24px;border-top:2px solid #f3f4f6;background:#f9fafb;border-radius:0 0 16px 16px}.cancel-btn,.confirm-btn{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn{background:#fff;color:#6b7280;border:2px solid #d1d5db}.cancel-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.confirm-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.confirm-btn:active:not(:disabled){transform:translateY(0)}.confirm-btn:disabled,.cancel-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 640px){.pin-dialog{width:95%;max-height:95vh}.pin-dialog-header{padding:16px 20px}.pin-dialog-header h3{font-size:18px}.pin-dialog-content{padding:20px;gap:20px}.pin-dialog-footer{flex-direction:column;padding:16px 20px}.cancel-btn,.confirm-btn{width:100%}.summary-row{flex-direction:column;align-items:flex-start;gap:4px}.summary-value{max-width:100%;text-align:left}}.collection-overview{width:100%;max-width:100%;margin:0;padding:20px}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.overview-header h2{margin:0;font-size:1.4rem;color:#333;font-weight:600}.refresh-button{background:#fff;border:1px solid #ddd;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;color:#666;transition:all .2s ease}.refresh-button:hover{background:#f5f5f5;border-color:#999;color:#333}.collection-overview .stats-cards{display:grid!important;grid-template-columns:repeat(4,1fr)!important;grid-auto-flow:column!important;gap:1rem;margin-bottom:1.5rem}.collection-overview .stats-cards .stat-card{min-width:0!important;width:100%!important}.stat-card{background:#fff;border-radius:8px;padding:1rem;box-shadow:0 2px 6px #00000014;transition:transform .2s ease,box-shadow .2s ease;border-left:3px solid}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0000001f}.stat-card.blue{border-left-color:#3498db}.stat-card.green{border-left-color:#2ecc71}.stat-card.purple{border-left-color:#9b59b6}.stat-card.orange{border-left-color:#e67e22}.card-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.8rem}.card-icon{font-size:1.3rem}.card-title{font-size:.8rem;color:#666;font-weight:500}.card-content .amount{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:.2rem}.card-content .count{font-size:.8rem;color:#7f8c8d}.pending-summary{background:#fff;border-radius:8px;padding:1.2rem;box-shadow:0 2px 6px #00000014;margin-bottom:1.5rem}.pending-summary h3{margin:0 0 .8rem;font-size:1.1rem;color:#333;font-weight:600}.pending-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.8rem}.pending-card{background:#f8f9fa;border-radius:6px;padding:.8rem;border:1px solid #e9ecef}.pending-label{font-size:.8rem;color:#6c757d;margin-bottom:.4rem}.pending-amount,.pending-count,.pending-date{font-size:1.2rem;font-weight:600;color:#495057}.pending-pool-section{background:#fff;border-radius:8px;padding:1.2rem;box-shadow:0 2px 6px #00000014;margin-bottom:1.5rem}.pool-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.pool-header h3{margin:0;font-size:1.1rem;color:#333;font-weight:600}.pool-count{font-size:.85rem;color:#667eea;font-weight:600;background:#f0f4ff;padding:.3rem .8rem;border-radius:12px}.pool-table-container{overflow-x:auto;border-radius:6px;border:1px solid #e5e7eb;min-width:1000px}.pool-table{width:100%;min-width:1000px;border-collapse:collapse;font-size:.85rem}.pool-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.pool-table th{padding:.7rem .8rem;text-align:left;font-weight:600;color:#374151;font-size:.75rem;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.pool-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s}.pool-table tbody tr:hover{background-color:#f9fafb}.pool-table tbody tr:last-child{border-bottom:none}.pool-table td{padding:.8rem;vertical-align:middle}.submitter-cell{display:flex;align-items:center;gap:.6rem}.role-icon{font-size:1.3rem;flex-shrink:0}.submitter-name{font-weight:600;color:#1f2937;font-size:.85rem}.submitter-meta{font-size:.7rem;color:#6b7280}.role-badge{padding:.15rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;display:inline-block}.amount-cell{font-size:.95rem;font-weight:700;color:#10b981;white-space:nowrap}.time-cell{color:#6b7280;font-size:.8rem;white-space:nowrap}.note-cell{max-width:200px;color:#4b5563;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.note-cell.empty{color:#d1d5db;font-style:italic}.action-cell{text-align:right}.claim-button{padding:.4rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:5px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #10b98140;white-space:nowrap}.claim-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #10b98159}.claim-button:active:not(:disabled){transform:translateY(0)}.claim-button:disabled{background:#d1d5db;cursor:not-allowed;box-shadow:none}.pool-empty{text-align:center;padding:2.5rem 1rem;color:#9ca3af}.pool-empty .empty-icon{font-size:3rem;margin-bottom:.8rem;opacity:.5}.pool-empty .empty-message{font-size:1rem;font-weight:600;color:#6b7280;margin-bottom:.4rem}.pool-empty .empty-hint{font-size:.85rem;color:#9ca3af}.last-collection{background:#fff;border-radius:8px;padding:1.2rem;box-shadow:0 2px 6px #00000014}.last-collection h3{margin:0 0 .6rem;font-size:1.1rem;color:#333;font-weight:600}.last-collection-time{font-size:1rem;color:#666;margin:0}.collection-history{width:100%;max-width:100%;margin:0;padding:20px;overflow-x:auto}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem}.header-title h2{font-size:1.4rem;font-weight:600;color:#1f2937;margin:0}.header-subtitle{font-size:.8rem;color:#6b7280;margin:.3rem 0 0}.refresh-button{padding:.5rem 1rem;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .2s}.refresh-button:hover{background:#f9fafb;border-color:#9ca3af}.collection-history .history-stats{display:grid!important;grid-template-columns:repeat(3,1fr)!important;grid-auto-flow:column!important;gap:1rem;margin-bottom:1.2rem}.collection-history .history-stats .stat-card{min-width:0!important;width:100%!important}.stat-card{background:#fff;border-radius:6px;padding:.8rem 1rem;border:1px solid #e5e7eb;transition:all .2s}.stat-card:hover{border-color:#9ca3af;box-shadow:0 2px 6px #00000014}.stat-content{display:flex;flex-direction:column;gap:.3rem}.stat-label{font-size:.75rem;color:#6b7280;font-weight:500}.stat-value{font-size:1.3rem;font-weight:700;color:#1f2937;line-height:1}.stat-amount{font-size:.85rem;color:#374151;font-weight:600}.fm-statistics{background:#fff;border-radius:6px;padding:1rem;margin-bottom:1.2rem;border:1px solid #e5e7eb}.fm-statistics h3{margin:0 0 .8rem;font-size:1rem;color:#374151;font-weight:600}.fm-list{display:flex;gap:1.5rem;flex-wrap:wrap}.fm-item{display:flex;align-items:center;gap:.6rem;padding:.5rem 1rem;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.fm-name{font-size:.85rem;font-weight:600;color:#1f2937}.fm-count{font-size:.8rem;color:#667eea;font-weight:600;background:#f0f4ff;padding:.2rem .6rem;border-radius:10px}.fm-amount{font-size:.8rem;color:#10b981;font-weight:600}.history-filters{display:flex;gap:.8rem;margin-bottom:1.2rem;padding:1rem;background:#fff;border-radius:6px;align-items:flex-end;border:1px solid #e5e7eb}.filter-group{display:flex;flex-direction:column;gap:.4rem}.filter-group label{font-size:.75rem;font-weight:600;color:#374151}.filter-select{padding:.45rem .8rem;border:1px solid #d1d5db;border-radius:4px;background:#fff;font-size:.8rem;min-width:110px;cursor:pointer;transition:all .2s;color:#374151}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-group{flex:1;min-width:200px}.search-wrapper{position:relative}.search-input{width:100%;padding:.45rem 2rem .45rem .8rem;border:1px solid #d1d5db;border-radius:4px;font-size:.8rem;transition:all .2s}.clear-search-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#9ca3af;cursor:pointer;font-size:1rem;padding:.2rem;line-height:1;transition:color .2s}.clear-search-btn:hover{color:#6b7280}.reset-filters-btn{padding:.45rem 1rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;color:#6b7280;transition:all .2s;white-space:nowrap}.reset-filters-btn:hover{background:#e5e7eb;border-color:#9ca3af;color:#374151}.table-container{background:#fff;border-radius:6px;overflow-x:auto;border:1px solid #e5e7eb;min-width:0!important;width:100%;overflow-x:hidden!important}.history-table{width:100%!important;table-layout:fixed;min-width:0!important;border-collapse:collapse;font-size:.8rem}.history-table thead th,.history-table th,.history-table td{white-space:normal;word-break:break-word;overflow-wrap:break-word}.history-table th:nth-child(1){width:18%;min-width:150px}.history-table th:nth-child(2){width:120px;min-width:100px}.history-table th:nth-child(3){width:120px;min-width:100px}.history-table th:nth-child(4){width:120px;min-width:100px}.history-table th:nth-child(5){width:100px;min-width:80px}.history-table th:nth-child(6){width:160px;min-width:120px}.history-table th:nth-child(7){width:140px;min-width:100px}.history-table th:nth-child(8){width:60px;min-width:60px}.history-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.history-table th{padding:.7rem .6rem;text-align:left;font-weight:600;color:#374151;font-size:.7rem;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.history-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .15s}.history-table tbody tr:hover{background-color:#f9fafb}.history-table tbody tr:last-child{border-bottom:none}.history-table td{padding:.7rem .6rem;vertical-align:middle}.history-table tbody tr.status-confirmed{border-left:3px solid #10b981}.history-table tbody tr.status-pending{border-left:3px solid #f59e0b}.history-table tbody tr.status-disputed{border-left:3px solid #ef4444}.history-table tbody tr.status-rejected{border-left:3px solid #dc2626}.submitter-cell{display:flex;align-items:center;gap:.5rem}.role-icon{font-size:1.2rem;flex-shrink:0}.submitter-info{display:flex;flex-direction:column;gap:.2rem}.submitter-name{font-weight:600;color:#1f2937;font-size:.8rem}.submitter-meta{font-size:.65rem;color:#6b7280}.role-badge{padding:.15rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;display:inline-block}.phone-cell{color:#4b5563;font-size:.75rem;white-space:nowrap}.employee-id-cell{color:#4b5563;font-size:.75rem;font-family:Courier New,monospace}.amount-cell{font-size:.9rem;font-weight:700;color:#10b981;white-space:nowrap}.status-badge{padding:.2rem .6rem;border-radius:8px;font-size:.65rem;font-weight:600;white-space:nowrap;display:inline-block}.status-badge.status-confirmed{background:#d1fae5;color:#065f46}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-disputed,.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.time-cell{color:#6b7280;font-size:.75rem;white-space:nowrap}.receiver-cell{color:#4b5563;font-size:.75rem;font-weight:500}.detail-cell{text-align:center}.detail-button{padding:.3rem .6rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.7rem;color:#6b7280;font-weight:500;transition:all .2s;white-space:nowrap}.detail-button:hover{background:#e5e7eb;border-color:#9ca3af;color:#374151}.expanded-row{background:#f9fafb}.expanded-content{padding:1rem}.expanded-section{margin-bottom:.8rem}.expanded-section:last-child{margin-bottom:0}.section-title{font-size:.75rem;font-weight:600;color:#6b7280;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.3px}.confirmed-info{padding:.6rem .8rem;background:#d1fae5;border-radius:4px;border-left:3px solid #10b981}.confirmed-item{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.4rem}.confirmed-item:last-child{margin-bottom:0}.confirmed-label{font-size:.7rem;color:#065f46;font-weight:600}.confirmed-value{font-size:.75rem;color:#047857;font-weight:500}.pointcard-info{display:flex;gap:1rem;padding:.6rem .8rem;background:#fef3c7;border-radius:4px;border-left:3px solid #f59e0b}.pointcard-item{display:flex;align-items:baseline;gap:.4rem}.pointcard-label{font-size:.7rem;color:#92400e;font-weight:500}.pointcard-value{font-size:.75rem;color:#92400e;font-weight:600}.sales-table{width:100%;border-collapse:collapse;font-size:.75rem;background:#fff;border-radius:4px;overflow:hidden;border:1px solid #e5e7eb}.sales-table th,.sales-table td{padding:.5rem .7rem;text-align:left;border-bottom:1px solid #f3f4f6}.sales-table th{background:#f3f4f6;font-weight:600;color:#374151;font-size:.7rem;text-transform:uppercase;letter-spacing:.3px}.sales-table tr:last-child td{border-bottom:none}.sales-table tbody tr:hover{background:#f9fafb}.empty-state{text-align:center;padding:3rem 1rem;background:#fff;border-radius:6px;border:1px solid #e5e7eb}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-message{font-size:1rem;font-weight:600;color:#6b7280;margin-bottom:.5rem}.reset-btn{padding:.5rem 1.2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #667eea40}.reset-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea59}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr!important}.action-header{flex-direction:column;align-items:stretch!important}.submit-button{width:100%}.submissions-list{grid-template-columns:1fr!important}.modal{margin:1rem}.submission-header{flex-direction:column;align-items:flex-start!important}.submission-status{align-self:flex-start}}@media (max-width: 480px){.stat-value{font-size:1.25rem!important}.stat-icon{font-size:1.5rem!important}.action-title{font-size:1.125rem!important}}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.submission-card:hover{box-shadow:0 4px 12px #0000001a}.close-button:hover{color:#374151}.cancel-button:hover{background:#f3f4f6;border-color:#9ca3af}.confirm-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}input:focus,textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}button:disabled{cursor:not-allowed;opacity:.5}input:disabled,textarea:disabled{background:#f3f4f6;cursor:not-allowed}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.modal::-webkit-scrollbar{width:8px}.modal::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.modal::-webkit-scrollbar-thumb{background:#9ca3af;border-radius:4px}.modal::-webkit-scrollbar-thumb:hover{background:#6b7280}.seller-dashboard{min-height:100vh;background-color:#f5f5f5;display:flex;flex-direction:column;overflow-x:hidden}.dashboard-header{background-color:#fff;color:#111827;padding:1rem;box-shadow:0 2px 4px #0000000f}.header-content{max-width:600px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.dashboard-title{font-size:1.5rem;font-weight:700;margin:0}.dashboard-brand{display:flex;flex-direction:row;gap:12px;align-items:center}.dashboard-logo{height:60px;width:auto;object-fit:contain;display:block}.dashboard-eventName{font-size:.8rem;color:#374151;line-height:1}.brand-text{display:flex;flex-direction:column;gap:2px}.dashboard-subtitle{font-size:.92rem;font-weight:700;color:#111827;line-height:1}.subtitle-en{display:none}.dashboard-eventFooter{text-align:center;padding:.75rem 1rem;color:#374151;font-size:.95rem;background:transparent;width:100%;box-sizing:border-box;margin-top:1.5rem}.dashboard-eventFooter .dashboard-eventName{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:100%;box-sizing:border-box}.dashboard-eventFooter .dashboard-logo{width:96px;max-width:30%;height:auto;display:block}.dashboard-eventFooter .dashboard-eventName span,.dashboard-eventFooter .dashboard-eventName{font-size:.95rem;color:#374151;font-weight:600}.dashboard-copyright{font-size:.7rem;color:#a8a8a8;text-align:center;margin-top:.5rem;opacity:.7}.dashboard-userSmall{font-size:.75rem;color:#6b7280;line-height:1}.user-info{display:flex;align-items:center;gap:.75rem}.user-name{font-size:.9rem}.logout-button{background:transparent;color:#222c6e;border:none;padding:.5rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s,transform .12s;display:flex;align-items:center;justify-content:center;line-height:0}.logout-button:hover{background-color:#0000000f;transform:translateY(-1px)}.logout-button svg{color:inherit}.role-switcher-button{background:transparent;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:0;transition:transform .2s;border-radius:4px;color:#222c6e}.role-switcher-button:hover{background-color:#0000000f;transform:scale(1.1)}.role-switcher-button svg{color:inherit}.tab-navigation{display:flex;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000001a}.tab-icon{font-size:1.5rem}.dashboard-content{flex:1;padding:1rem;max-width:600px;margin:0 auto;width:100%}.seller-dashboard .header-content,.seller-dashboard .dashboard-content{max-width:600px;margin:0 auto;padding:0 1rem;box-sizing:border-box}.tab-navigation{width:100%;box-sizing:border-box}.seller-dashboard .dashboard-content>*{width:100%;box-sizing:border-box;margin-left:0;margin-right:0}.points-overview{display:flex;flex-direction:column;gap:1rem}.card{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.card-title{font-size:1.1rem;font-weight:700;margin:0 0 1rem;color:#333}.balance-display{text-align:center;margin:1.5rem 0}.balance-amount{font-size:3rem;font-weight:700;color:#2196f3}.balance-unit{font-size:1.2rem;color:#757575;margin-left:.5rem}.sub-info{text-align:center;color:#757575;font-size:.9rem;margin-bottom:1rem}.revenue-info{text-align:center;padding:.75rem;background-color:#e3f2fd;border-radius:4px;color:#1976d2;font-size:.95rem}.cash-stats{display:flex;flex-direction:column;gap:1rem;margin:1rem 0}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f9f9f9;border-radius:4px}.stat-label{font-size:.95rem;color:#666}.stat-value{font-size:1.1rem;font-weight:700}.stat-value.cash-on-hand{color:#4caf50}.stat-value.submitted{color:#ff9800}.stat-value.confirmed{color:#2196f3}.stat-value.sold{color:#9c27b0}.stat-value.pending{color:#f44336}.cash-total{text-align:center;padding:.75rem;background-color:#f3e5f5;border-radius:4px;color:#7b1fa2;font-size:.95rem;margin-top:.5rem}.sales-card{margin-top:1rem}.sales-stats{display:flex;flex-direction:column;gap:1rem;margin:1rem 0}.make-sale{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.section-title{font-size:1.3rem;font-weight:700;margin:0 0 1.5rem;color:#333}.form-section{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.95rem;font-weight:500;color:#333}.input-group{display:flex;gap:.5rem}.input-group input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.input-group input:focus{outline:none;border-color:#2196f3}.search-button{padding:.75rem 1.5rem;background-color:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.95rem;white-space:nowrap;transition:background-color .2s}.search-button:hover:not(:disabled){background-color:#1976d2}.search-button:disabled{background-color:#bdbdbd;cursor:not-allowed}.customer-info{padding:1rem;background-color:#e8f5e9;border:1px solid #4CAF50;border-radius:4px}.customer-name{font-size:1rem;margin-bottom:.5rem}.customer-balance{font-size:.95rem;color:#2e7d32}.amount-input-wrapper{position:relative}.amount-input-wrapper input{width:100%;padding:.75rem 3rem .75rem .75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.amount-input-wrapper input:focus{outline:none;border-color:#2196f3}.input-suffix{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#757575;font-size:.95rem;pointer-events:none}.balance-check{margin-top:.5rem;font-size:.9rem}.balance-ok{color:#4caf50}.balance-insufficient{color:#f44336}.error-message{padding:1rem;background-color:#ffebee;border:1px solid #F44336;border-radius:4px;color:#c62828;font-size:.95rem}.success-message{padding:1rem;background-color:#e8f5e9;border:1px solid #4CAF50;border-radius:4px;color:#2e7d32;font-size:.95rem}.submit-button{width:100%;padding:1rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#388e3c}.submit-button:disabled{background-color:#bdbdbd;cursor:not-allowed}.transaction-history{background-color:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.transaction-history{box-sizing:border-box;margin:0;padding:1.5rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;width:100%;overflow:hidden}.transactions-list,.transaction-summary,.transaction-item{box-sizing:border-box;width:100%}.no-transactions{text-align:center;padding:3rem 1rem;color:#757575}.no-transactions p{margin:.5rem 0}.no-transactions .hint{font-size:.9rem;color:#9e9e9e}.transactions-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.transaction-item{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;background-color:#fafafa}.transaction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e0e0e0;width:100%;box-sizing:border-box;min-width:0}.transaction-status{font-size:.85rem;font-weight:500;flex-shrink:0;min-width:0}.transaction-status.completed{color:#4caf50}.transaction-time{font-size:.85rem;color:#757575;flex-shrink:0;min-width:0;text-align:right}.transaction-details{display:flex;flex-direction:column;gap:.5rem;width:100%;box-sizing:border-box;overflow:hidden;word-break:break-word}.transaction-customer,.transaction-amount{font-size:.95rem;color:#333;width:100%;box-sizing:border-box;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.amount-value{color:#2196f3;font-size:1.1rem}.transaction-summary{display:flex;gap:1rem;padding:1rem;background-color:#e3f2fd;border-radius:8px}.summary-item{flex:1;text-align:center}.summary-label{display:block;font-size:.85rem;color:#1976d2;margin-bottom:.25rem}.summary-value{display:block;font-size:1.3rem;font-weight:700;color:#0d47a1}.loading-message,.no-data-message{text-align:center;padding:3rem 1rem;color:#757575;font-size:1rem}.success-box{background-color:#e8f5e9;border:1px solid #4CAF50}@media (max-width: 480px){.dashboard-header{padding:.75rem}.dashboard-title{font-size:1.2rem}.user-name{display:none}.balance-amount{font-size:2.5rem}.card,.make-sale,.transaction-history{padding:1rem}}@media (min-width: 768px){.dashboard-content{padding:2rem 1rem}}.seller-inventory{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:12px;margin-bottom:24px;text-align:center;box-shadow:0 4px 12px #667eea4d}.inventory-label{font-size:14px;opacity:.9;margin-bottom:8px;font-weight:500}.inventory-amount{font-size:48px;font-weight:700;margin:8px 0;text-shadow:0 2px 4px rgba(0,0,0,.2)}.inventory-hint{font-size:13px;opacity:.85;margin-top:4px}.sales-stats{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.stat-label{color:#666;font-size:14px}.stat-value{color:#333;font-weight:600;font-size:16px}.cash-summary{display:flex;flex-direction:column;gap:16px}.cash-item{display:flex;flex-direction:column;gap:4px}.cash-item.highlight{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:16px;border-radius:8px;margin:-8px -8px 0}.cash-label{font-size:13px;opacity:.85}.cash-item.highlight .cash-label{opacity:.95;font-weight:500}.cash-amount{font-size:32px;font-weight:700}.cash-amount.secondary{font-size:20px;color:#555}.cash-hint{font-size:12px;opacity:.8;margin-top:4px}.cash-divider{height:1px;background:#e0e0e0;margin:8px 0}.collection-reminder{display:flex;align-items:center;gap:8px;background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:12px;margin-top:16px}.reminder-icon{font-size:20px}.reminder-text{font-size:13px;color:#856404;font-weight:500}.info-card{background:#f8f9fa;border-left:4px solid #667eea}.info-title{font-size:14px;font-weight:600;color:#333;margin-bottom:12px}.info-list{list-style:none;padding:0;margin:0}.info-list li{font-size:13px;color:#555;padding:6px 0 6px 20px;position:relative}.info-list li:before{content:"•";position:absolute;left:8px;color:#667eea;font-weight:700}.balance-check{margin-top:8px;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:500}.balance-ok{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb;padding:6px 12px;border-radius:4px;display:inline-block}.balance-insufficient{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;padding:6px 12px;border-radius:4px;display:inline-block}.submit-button{width:100%;padding:14px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;margin-top:16px}.submit-button:disabled{background:linear-gradient(135deg,#ccc,#999);cursor:not-allowed;box-shadow:none}.customer-info{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;padding:16px;margin:16px 0}.customer-name{font-size:15px;color:#155724;margin-bottom:8px}.customer-balance{font-size:14px;color:#155724;font-weight:500}@media (max-width: 768px){.inventory-amount{font-size:36px}.cash-amount{font-size:28px}.stat-row{font-size:14px}}.merchant-qr-container{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;padding:1.5rem}.merchant-qr-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.merchant-qr-icon{width:2.5rem;height:2.5rem;background-color:#f3e8ff;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.merchant-qr-icon svg{width:1.5rem;height:1.5rem;color:#9333ea}.merchant-qr-title h3{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.merchant-qr-title p{font-size:.875rem;color:#6b7280;margin:0}.merchant-qr-display{background:linear-gradient(to bottom right,#f3e8ff,#dbeafe);border-radius:.75rem;padding:2rem;margin-bottom:1.5rem}.merchant-qr-card{background-color:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 10px 15px -3px #0000001a;max-width:20rem;margin:0 auto}.merchant-qr-code{display:flex;justify-content:center;margin-bottom:1rem}.merchant-qr-info{text-align:center;border-top:1px solid #e5e7eb;padding-top:1rem}.merchant-qr-info h4{font-size:1.125rem;font-weight:700;color:#111827;margin:0 0 .25rem}.merchant-qr-description{font-size:.875rem;color:#4b5563;margin:0 0 .5rem}.merchant-qr-instruction{font-size:.75rem;color:#6b7280;margin:0}.merchant-qr-alert{background-color:#dbeafe;border:1px solid #93c5fd;border-radius:.5rem;padding:1rem;margin-bottom:1rem}.merchant-qr-alert-content{display:flex;gap:.75rem}.merchant-qr-alert-icon{width:1.25rem;height:1.25rem;color:#2563eb;flex-shrink:0;margin-top:.125rem}.merchant-qr-alert-text{font-size:.875rem;color:#1e3a8a}.merchant-qr-alert-text p:first-child{font-weight:500;margin:0 0 .25rem}.merchant-qr-alert-text ul{list-style:disc;list-style-position:inside;margin:0;padding:0}.merchant-qr-alert-text li{color:#1e40af;margin:.25rem 0}.merchant-qr-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.merchant-qr-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;border-radius:.5rem;font-weight:500;cursor:pointer;transition:background-color .2s}.merchant-qr-btn svg{width:1.25rem;height:1.25rem}.merchant-qr-btn.download{background-color:#f3f4f6;color:#374151}.merchant-qr-btn.download:hover{background-color:#e5e7eb}.merchant-qr-btn.share{background-color:#9333ea;color:#fff}.merchant-qr-btn.share:hover{background-color:#7e22ce}.merchant-qr-share-error{margin-top:1rem;padding:.75rem;background-color:#fef3c7;border:1px solid #fcd34d;border-radius:.5rem}.merchant-qr-share-error p{font-size:.875rem;color:#92400e;margin:0}.merchant-qr-loading{display:flex;align-items:center;justify-content:center;padding:2rem}.merchant-qr-loading-content{text-align:center}.merchant-qr-loading-icon{width:3rem;height:3rem;color:#9ca3af;margin:0 auto .5rem}.merchant-qr-loading-text{color:#6b7280;margin:0}details summary{font-size:.75rem;color:#6b7280;cursor:pointer}details summary:hover{color:#374151}details>div{margin-top:.5rem;padding:.75rem;background-color:#f9fafb;border-radius:.25rem;font-size:.75rem;font-family:monospace;color:#4b5563}details>div>div{margin:.25rem 0}.merchant-stats-grid{display:grid;grid-template-columns:1fr;gap:1rem}.merchant-owner-summary{width:100%}.merchant-summary-card{padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #2196f34d;color:#fff;background:linear-gradient(135deg,#2196f3,#1976d2)}.merchant-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.merchant-summary-label{font-size:.9rem;opacity:.9}.merchant-summary-badge{padding:.5rem 1rem;font-size:.8rem;background-color:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px}.merchant-summary-amount{margin-bottom:1.5rem}.merchant-summary-number{font-size:2.5rem;font-weight:700;margin-right:.5rem}.merchant-summary-unit{font-size:1.2rem;opacity:.9}.merchant-summary-stats{display:flex;justify-content:space-around;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.merchant-summary-stat-item{display:flex;flex-direction:column;align-items:center}.merchant-summary-stat-value{font-size:1.2rem;font-weight:600}.merchant-summary-stat-label{font-size:.8rem;opacity:.8;margin-top:.25rem}.merchant-summary-stat-divider{width:1px;background-color:#fff3}@media (min-width: 768px){.merchant-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.merchant-stats-grid{grid-template-columns:repeat(3,1fr)}}.stat-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;padding:1rem;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 6px -1px #0000001a}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.stat-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.stat-icon svg{width:1.5rem;height:1.5rem}.stat-icon.purple{background-color:#f3e8ff}.stat-icon.purple svg{color:#9333ea}.stat-icon.blue{background-color:#dbeafe}.stat-icon.blue svg{color:#2563eb}.stat-icon.green{background-color:#d1fae5}.stat-icon.green svg{color:#059669}.stat-icon.orange{background-color:#fed7aa}.stat-icon.orange svg{color:#ea580c}.stat-trend{font-size:.75rem;font-weight:500}.stat-trend.positive{color:#059669}.stat-trend.neutral{color:#6b7280}.stat-card-content p:first-child{font-size:.875rem;color:#4b5563;margin:0 0 .25rem}.stat-value{font-size:1.5rem;font-weight:700;color:#111827;margin:0}.stat-subvalue{font-size:.75rem;color:#6b7280;margin:.25rem 0 0}.stat-skeleton-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 768px){.stat-skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.stat-skeleton-grid{grid-template-columns:repeat(3,1fr)}}.stat-skeleton{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;padding:1rem;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton-icon{width:2.5rem;height:2.5rem;background-color:#e5e7eb;border-radius:.5rem;margin-bottom:.75rem}.skeleton-label{height:1rem;background-color:#e5e7eb;border-radius:.25rem;width:5rem;margin-bottom:.5rem}.skeleton-value{height:2rem;background-color:#e5e7eb;border-radius:.25rem;width:6rem}.merchant-transactions-container{width:100%;max-width:1200px;margin:0 auto;padding:0}.transactions-tabs{display:flex;gap:8px;padding:16px;background:#fff;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10}.transactions-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#666;position:relative}.transactions-tab svg{width:18px;height:18px}.transactions-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}.transactions-tab:hover:not(.active){background:#f5f5f5;border-color:#667eea}.tab-label{font-size:14px}.tab-badge{position:absolute;top:-6px;right:-6px;background:#f44336;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:600;min-width:18px;text-align:center;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.transactions-content{padding:16px;background:#f5f5f5;min-height:400px}.transactions-list{width:100%}.pending-payments-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.pending-payment-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000001a;transition:all .2s;border:2px solid #ffd54f;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pending-payment-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.pending-payment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.pending-payment-customer{display:flex;align-items:center;gap:12px}.customer-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff}.customer-avatar svg{width:20px;height:20px}.customer-info{display:flex;flex-direction:column}.customer-name{font-weight:600;font-size:15px;color:#333;margin:0}.customer-phone{font-size:12px;color:#999;margin:2px 0 0}.pending-payment-amount{display:flex;align-items:baseline;gap:4px;font-weight:700}.amount-value{font-size:24px;color:#f57c00}.amount-unit{font-size:14px;color:#999}.pending-payment-time{display:flex;align-items:center;gap:6px;font-size:12px;color:#666;margin-bottom:12px;padding:8px;background:#f5f5f5;border-radius:6px}.time-icon{width:14px;height:14px}.pending-payment-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.confirm-btn,.cancel-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.confirm-btn{background:#4caf50;color:#fff}.confirm-btn:hover:not(:disabled){background:#45a049;transform:scale(1.02)}.confirm-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.cancel-btn{background:#fff;color:#f44336;border:1px solid #f44336}.cancel-btn:hover:not(:disabled){background:#ffebee}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-btn svg,.cancel-btn svg{width:16px;height:16px}.transactions-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.transaction-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #0000001a;transition:all .2s}.transaction-card:hover{box-shadow:0 4px 16px #00000026}.transaction-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.transaction-customer{display:flex;align-items:center;gap:12px}.transaction-status{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600}.status-icon{width:14px;height:14px}.transaction-amount{display:flex;align-items:baseline;gap:4px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.transaction-amount .amount-value{font-size:28px;color:#333}.transaction-details{display:flex;flex-direction:column;gap:8px}.detail-row{display:flex;justify-content:space-between;align-items:flex-start;font-size:13px}.detail-label{color:#999;flex-shrink:0;margin-right:12px}.detail-value{color:#333;text-align:right;flex:1}.refund-reason,.cancel-reason{font-style:italic;color:#666}.transaction-actions{margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.refund-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;background:#fff;color:#f57c00;border:1px solid #f57c00;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.refund-btn:hover{background:#fff3e0}.refund-btn svg{width:16px;height:16px}.refund-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.refund-dialog{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:100%;box-shadow:0 8px 32px #0003}.refund-dialog-title{font-size:18px;font-weight:600;margin-bottom:16px;color:#333}.refund-dialog-info{font-size:14px;color:#666;margin-bottom:16px}.refund-dialog-info strong{color:#f57c00}.refund-reason-input{width:100%;padding:12px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;resize:vertical;margin-bottom:16px;font-family:inherit}.refund-reason-input:focus{outline:none;border-color:#667eea}.refund-dialog-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.refund-confirm-btn,.refund-cancel-btn{padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.refund-confirm-btn{background:#f57c00;color:#fff}.refund-confirm-btn:hover:not(:disabled){background:#ef6c00}.refund-confirm-btn:disabled{background:#ccc;cursor:not-allowed}.refund-cancel-btn{background:#fff;color:#666;border:1px solid #e0e0e0}.refund-cancel-btn:hover:not(:disabled){background:#f5f5f5}.transactions-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{width:64px;height:64px;color:#ccc;margin-bottom:16px}.empty-title{font-size:18px;font-weight:600;color:#333;margin-bottom:8px}.empty-text{font-size:14px;color:#999}.transactions-loading,.transactions-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;color:#667eea;margin-bottom:16px;animation:spin 1s linear infinite}.error-icon{width:48px;height:48px;color:#f44336;margin-bottom:16px}.transactions-loading p,.transactions-error p{font-size:14px;color:#666}.transactions-role-notice{position:sticky;bottom:0;display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fff3e0;border-top:1px solid #ffb74d;font-size:13px;color:#f57c00}.notice-icon{width:16px;height:16px;flex-shrink:0}@media (max-width: 768px){.transactions-tabs{gap:6px;padding:12px}.transactions-tab{flex-direction:column;gap:4px;padding:10px 8px;font-size:12px}.transactions-tab svg{width:20px;height:20px}.tab-label{font-size:11px}.pending-payments-grid,.transactions-grid{grid-template-columns:1fr}.refund-dialog{max-width:100%}}.merchant-profile-container{display:flex;flex-direction:column;gap:1rem}.merchant-status-card{border-radius:.5rem;padding:1rem}.merchant-status-card.active{background:linear-gradient(to right,#d1fae5,#a7f3d0);border:1px solid #6ee7b7}.merchant-status-card.inactive{background:linear-gradient(to right,#fed7aa,#fef3c7);border:1px solid #fdba74}.merchant-status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.merchant-status-info{display:flex;align-items:center;gap:.75rem}.merchant-status-icon{width:2.5rem;height:2.5rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.merchant-status-icon.active{background-color:#d1fae5}.merchant-status-icon.active svg{width:1.5rem;height:1.5rem;color:#059669}.merchant-status-icon.inactive{background-color:#fed7aa}.merchant-status-icon.inactive svg{width:1.5rem;height:1.5rem;color:#ea580c}.merchant-status-text p:first-child{font-weight:600;color:#111827;margin:0}.merchant-status-text p:last-child{font-size:.875rem;color:#4b5563;margin:0}.merchant-status-toggle{padding:.5rem 1rem;border-radius:.5rem;font-weight:500;border:none;cursor:pointer;transition:background-color .2s}.merchant-status-toggle.to-pause{background-color:#ea580c;color:#fff}.merchant-status-toggle.to-pause:hover{background-color:#c2410c}.merchant-status-toggle.to-start{background-color:#059669;color:#fff}.merchant-status-toggle.to-start:hover{background-color:#047857}.merchant-status-toggle:disabled{opacity:.5;cursor:not-allowed}.merchant-profile-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;border:1px solid #e5e7eb;padding:1.5rem}.merchant-profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.merchant-profile-title{display:flex;align-items:center;gap:.75rem}.merchant-profile-icon{width:2.5rem;height:2.5rem;background-color:#f3e8ff;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.merchant-profile-icon svg{width:1.5rem;height:1.5rem;color:#9333ea}.merchant-profile-title h3{font-size:1.125rem;font-weight:600;color:#111827;margin:0}.merchant-edit-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:#9333ea;background-color:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-edit-btn:hover{background-color:#faf5ff}.merchant-edit-btn svg{width:1rem;height:1rem}.merchant-error-alert{margin-bottom:1rem;padding:.75rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;display:flex;align-items:flex-start;gap:.5rem}.merchant-error-alert svg{width:1.25rem;height:1.25rem;color:#dc2626;flex-shrink:0;margin-top:.125rem}.merchant-error-alert p{font-size:.875rem;color:#991b1b;margin:0}.merchant-form{display:flex;flex-direction:column;gap:1rem}.merchant-form-field label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.merchant-form-field label svg{display:inline;width:1rem;height:1rem;margin-right:.25rem}.merchant-form-field .required{color:#dc2626}.merchant-form-field input,.merchant-form-field textarea{width:100%;padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:.5rem;box-sizing:border-box}.merchant-form-field input:focus,.merchant-form-field textarea:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px #9333ea}.merchant-form-field .view-only{color:#111827;margin:0}.merchant-form-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.merchant-save-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background-color:#9333ea;color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-save-btn:hover{background-color:#7e22ce}.merchant-save-btn:disabled{opacity:.5;cursor:not-allowed}.merchant-save-btn svg{width:1rem;height:1rem}.merchant-cancel-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background-color:#f3f4f6;color:#374151;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-cancel-btn:hover{background-color:#e5e7eb}.merchant-cancel-btn:disabled{opacity:.5;cursor:not-allowed}.merchant-cancel-btn svg{width:1rem;height:1rem}.merchant-meta-info{background-color:#f9fafb;border-radius:.5rem;padding:1rem}.merchant-meta-info>p:first-child{font-size:.875rem;color:#4b5563;margin:0 0 .5rem}.merchant-meta-list{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.merchant-meta-row{display:flex;justify-content:space-between}.merchant-meta-row span:first-child{color:#6b7280}.merchant-meta-row span:last-child{color:#111827;font-family:monospace}.pin-dialog-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.pin-dialog{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.pin-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid #e2e8f0}.pin-dialog-header h3{font-size:20px;font-weight:700;color:#2d3748;margin:0}.close-button{width:36px;height:36px;border:none;background:#f7fafc;border-radius:50%;font-size:20px;color:#718096;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.close-button:hover{background:#e2e8f0;color:#2d3748}.pin-dialog-content{padding:24px;display:flex;flex-direction:column;gap:24px}.message-box{background:#ebf8ff;border:2px solid #90cdf4;border-radius:8px;padding:16px}.message-text{font-size:15px;color:#2c5282;margin:0;line-height:1.6}.pin-input-section{display:flex;flex-direction:column;gap:12px}.pin-label{font-size:14px;font-weight:600;color:#2d3748;display:flex;align-items:center;gap:8px}.label-icon{font-size:18px}.pin-input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:18px;font-weight:600;letter-spacing:8px;text-align:center;transition:all .3s ease}.pin-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.pin-input.error{border-color:#fc8181;background:#fff5f5}.pin-input::placeholder{letter-spacing:normal;font-weight:400;opacity:.5}.pin-dots{display:flex;justify-content:center;gap:12px;margin-top:8px}.pin-dot{width:12px;height:12px;border-radius:50%;background:#e2e8f0;transition:all .2s ease}.pin-dot.filled{background:#667eea;transform:scale(1.2)}.error-message{color:#c53030;font-size:13px;margin:0;padding:8px 12px;background:#fff5f5;border-radius:6px;border:1px solid #fc8181}.note-section{display:flex;flex-direction:column;gap:8px}.note-label{font-size:14px;font-weight:600;color:#2d3748}.note-textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:all .3s ease}.note-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.char-count{font-size:12px;color:#a0aec0;text-align:right}.security-tip{display:flex;gap:12px;align-items:flex-start;padding:12px;background:#fffaf0;border:1px solid #fbd38d;border-radius:8px}.tip-icon{font-size:20px;flex-shrink:0}.tip-text{font-size:13px;color:#744210;line-height:1.5}.pin-dialog-footer{display:flex;gap:12px;padding:24px;border-top:2px solid #e2e8f0}.cancel-btn,.confirm-btn{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-btn{background:#f7fafc;color:#4a5568}.cancel-btn:hover:not(:disabled){background:#e2e8f0}.confirm-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cancel-btn:disabled,.confirm-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.pin-dialog{width:95%;max-height:95vh}.pin-dialog-header,.pin-dialog-content,.pin-dialog-footer{padding:20px}.pin-dialog-header h3{font-size:18px}.pin-input{font-size:16px;letter-spacing:6px}.pin-dots{gap:10px}.pin-dot{width:10px;height:10px}.pin-dialog-footer{flex-direction:column}.cancel-btn,.confirm-btn{width:100%}}.merchant-scanner{padding:1.5rem;max-width:600px;margin:0 auto}.scanner-header{text-align:center;margin-bottom:2rem}.scanner-header .scanner-icon{width:3rem;height:3rem;color:#2196f3;margin:0 auto 1rem}.scanner-header h2{font-size:1.5rem;font-weight:600;color:#212121;margin-bottom:.5rem}.scanner-header p{color:#757575;font-size:.95rem}.scanner-error{background:#ffebee;border:1px solid #ef5350;border-radius:8px;padding:1rem;margin-bottom:1.5rem;display:flex;align-items:flex-start;gap:.75rem}.scanner-error svg{width:1.25rem;height:1.25rem;color:#d32f2f;flex-shrink:0;margin-top:.125rem}.scanner-error p{flex:1;color:#c62828;font-size:.9rem;margin:0}.scanner-error .error-dismiss{background:#d32f2f;color:#fff;border:none;border-radius:4px;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;transition:background .2s}.scanner-error .error-dismiss:hover{background:#b71c1c}.scanner-start{text-align:center}.start-scan-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;border:none;border-radius:12px;padding:1.25rem 2rem;font-size:1.1rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.75rem;box-shadow:0 4px 12px #2196f34d;transition:all .3s}.start-scan-btn:hover{background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 6px 16px #2196f366;transform:translateY(-2px)}.start-scan-btn svg{width:1.5rem;height:1.5rem}.scanner-instructions{margin-top:2.5rem;background:#f5f5f5;border-radius:12px;padding:1.5rem;text-align:left}.scanner-instructions h3{font-size:1rem;font-weight:600;color:#424242;margin-bottom:1rem}.scanner-instructions ul{list-style:none;padding:0;margin:0}.scanner-instructions li{padding:.75rem 0 .75rem 2rem;position:relative;color:#616161;font-size:.95rem;line-height:1.5}.scanner-instructions li:before{content:"✓";position:absolute;left:.5rem;color:#4caf50;font-weight:700}.scanner-camera{background:#fff;border-radius:12px;padding:.5rem;box-shadow:0 2px 8px #0000001a}.scanner-tips{background:#2196f31a;border-left:3px solid #2196F3;border-radius:4px;padding:.5rem .75rem;margin-bottom:.5rem}.scanner-tips p{margin:0;font-size:.85rem;color:#1976d2;font-weight:500}#merchant-qr-reader{width:100%;min-height:70vh;max-height:75vh;border-radius:8px;overflow:hidden;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center}#merchant-qr-reader video{width:100%!important;height:100%!important;object-fit:cover}.stop-scan-btn{background:#f44336;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s;margin:0 auto;display:block}.stop-scan-btn:hover{background:#d32f2f}.card-info-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.card-info-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.card-info-header .card-icon{width:2rem;height:2rem;color:#ff9800}.card-info-header h2{font-size:1.25rem;font-weight:600;color:#212121;margin:0}.card-details{background:#fafafa;border-radius:8px;padding:1.25rem;margin-bottom:1.5rem}.card-detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e0e0e0}.card-detail-row:last-child{border-bottom:none}.detail-label{font-size:.95rem;color:#757575}.detail-value{font-size:1rem;font-weight:600;color:#424242}.detail-value.balance{color:#4caf50;font-size:1.25rem}.card-status-error{background:#ffebee;border:1px solid #ef5350;border-radius:6px;padding:.75rem;margin-top:1rem;display:flex;align-items:center;gap:.5rem}.card-status-error svg{width:1rem;height:1rem;color:#d32f2f}.card-status-error p{margin:0;color:#c62828;font-size:.9rem;font-weight:500}.amount-input-section{margin-bottom:1.5rem}.amount-input-section label{display:block;font-size:.95rem;font-weight:500;color:#424242;margin-bottom:.5rem}.amount-input-wrapper{display:flex;align-items:center;gap:.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:.5rem 1rem;transition:border-color .2s}.amount-input-wrapper:focus-within{border-color:#2196f3}.amount-input-wrapper input{flex:1;border:none;outline:none;font-size:1.25rem;font-weight:600;color:#212121}.amount-input-wrapper input::placeholder{color:#bdbdbd;font-weight:400}.amount-input-wrapper .input-suffix{font-size:1rem;color:#757575;font-weight:500}.amount-error{color:#d32f2f;font-size:.85rem;margin:.5rem 0 0}.amount-hint{color:#757575;font-size:.85rem;margin:.5rem 0 0}.card-actions{display:flex;gap:1rem}.card-actions button{flex:1;padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.card-actions .cancel-btn{background:#f5f5f5;color:#616161}.card-actions .cancel-btn:hover{background:#e0e0e0}.card-actions .confirm-btn{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;box-shadow:0 2px 8px #4caf504d}.card-actions .confirm-btn:hover:not(:disabled){background:linear-gradient(135deg,#388e3c,#2e7d32);box-shadow:0 4px 12px #4caf5066;transform:translateY(-1px)}.card-actions .confirm-btn:disabled{background:#bdbdbd;box-shadow:none;cursor:not-allowed}.success-container{background:#fff;border-radius:12px;padding:2rem;text-align:center;box-shadow:0 2px 8px #0000001a}.success-icon{width:4rem;height:4rem;margin:0 auto 1.5rem;background:linear-gradient(135deg,#4caf50,#388e3c);border-radius:50%;display:flex;align-items:center;justify-content:center}.success-icon svg{width:2.5rem;height:2.5rem;color:#fff}.success-container h2{font-size:1.5rem;font-weight:600;color:#212121;margin-bottom:1.5rem}.success-details{background:#f5f5f5;border-radius:8px;padding:1.25rem;margin-bottom:1.5rem}.success-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e0e0e0}.success-row:last-child{border-bottom:none}.success-label{font-size:.95rem;color:#757575}.success-value{font-size:1.1rem;font-weight:600;color:#4caf50}.success-value.transaction-id{color:#757575;font-size:.9rem;font-family:monospace}.success-actions{margin-top:1.5rem}.scan-again-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff;border:none;border-radius:8px;padding:.875rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 2px 8px #2196f34d;transition:all .2s}.scan-again-btn:hover{background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f366;transform:translateY(-1px)}.scanner-loading{text-align:center;padding:3rem 1.5rem}.loading-spinner{width:3rem;height:3rem;border:3px solid #e0e0e0;border-top-color:#2196f3;border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}.scanner-loading p{color:#757575;font-size:1rem}@media (max-width: 480px){.merchant-scanner{padding:.5rem}.scanner-camera{padding:.25rem;border-radius:8px}#merchant-qr-reader{min-height:75vh;max-height:80vh;border-radius:4px}.scanner-header h2{font-size:1.25rem}.start-scan-btn{padding:1rem 1.5rem;font-size:1rem}.card-info-container{padding:1rem}.amount-input-wrapper input{font-size:1.1rem}.card-actions{flex-direction:column}.success-container{padding:1.5rem}}.merchant-dashboard{min-height:100vh;background-color:#f9fafb}.merchant-header{background-color:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;z-index:10;box-shadow:0 1px 2px #0000000d}.merchant-header-container{max-width:80rem;margin:0 auto;padding:1rem}.merchant-header-content{display:flex;align-items:center;justify-content:space-between}.merchant-logo-section{display:flex;align-items:center;gap:.75rem}.merchant-logo{width:2.5rem;height:2.5rem;background:linear-gradient(to bottom right,#9333ea,#2563eb);border-radius:.5rem;display:flex;align-items:center;justify-content:center}.merchant-logo svg{width:1.5rem;height:1.5rem;color:#fff}.merchant-title-section h1{font-size:1.125rem;font-weight:700;color:#111827;margin:0}.merchant-title-section p{font-size:.75rem;color:#6b7280;margin:0}.merchant-desktop-actions{display:none;align-items:center;gap:.75rem}@media (min-width: 768px){.merchant-desktop-actions{display:flex}}.merchant-refresh-btn{padding:.5rem 1rem;color:#374151;background-color:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-refresh-btn:hover{background-color:#f3f4f6}.merchant-logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;color:#dc2626;background-color:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-logout-btn:hover{background-color:#fef2f2}.merchant-logout-btn svg{width:1rem;height:1rem}.merchant-mobile-menu-btn{display:block;padding:.5rem;background-color:transparent;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}@media (min-width: 768px){.merchant-mobile-menu-btn{display:none}}.merchant-mobile-menu-btn:hover{background-color:#f3f4f6}.merchant-mobile-menu-btn svg{width:1.5rem;height:1.5rem}.merchant-mobile-menu{display:block;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}@media (min-width: 768px){.merchant-mobile-menu{display:none}}.merchant-mobile-menu button{width:100%;text-align:left;padding:.5rem 1rem;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-mobile-menu .refresh-item{color:#374151;background-color:transparent;margin-bottom:.5rem}.merchant-mobile-menu .refresh-item:hover{background-color:#f3f4f6}.merchant-mobile-menu .logout-item{color:#dc2626;background-color:transparent}.merchant-mobile-menu .logout-item:hover{background-color:#fef2f2}.merchant-main{max-width:80rem;margin:0 auto;padding:1.5rem 1rem}.merchant-stats-section{margin-bottom:1.5rem}.merchant-tabs-container{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 2px #0000000d;margin-bottom:1.5rem;overflow-x:auto}.merchant-tabs-nav{display:flex;border-bottom:1px solid #e5e7eb}.merchant-tab-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 1.5rem;font-weight:500;border:none;background:none;cursor:pointer;transition:color .2s;white-space:nowrap;border-bottom:2px solid transparent}.merchant-tab-btn.inactive{color:#4b5563}.merchant-tab-btn.inactive:hover{color:#111827}.merchant-tab-btn.active{color:#9333ea;border-bottom-color:#9333ea}.merchant-tab-btn svg{width:1.25rem;height:1.25rem}.tab-navigation{display:flex;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000001a;background-color:#fff}.tab-button{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem .5rem;background:transparent;border:none;cursor:pointer;color:#757575;transition:all .2s;border-bottom:3px solid transparent}.tab-button svg{color:inherit}.tab-button.active{color:#2196f3;border-bottom-color:#2196f3}.tab-icon-img{width:1.5rem;height:1.5rem;display:block;object-fit:contain}.tab-label{font-size:.85rem;font-weight:500}.merchant-loading{min-height:100vh;background-color:#f9fafb;display:flex;align-items:center;justify-content:center}.merchant-loading-content{text-align:center}.merchant-loading-spinner{width:3rem;height:3rem;border:2px solid transparent;border-bottom-color:#9333ea;border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}.merchant-loading-text{color:#4b5563}.merchant-error{min-height:100vh;background-color:#f9fafb;display:flex;align-items:center;justify-content:center;padding:1rem}.merchant-error-card{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1.5rem;max-width:28rem;width:100%;text-align:center}.merchant-error-icon{width:3rem;height:3rem;background-color:#fee2e2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.merchant-error-icon svg{width:1.5rem;height:1.5rem;color:#dc2626}.merchant-error-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 .5rem}.merchant-error-message{color:#4b5563;margin:0 0 1rem}.merchant-error-btn{padding:.5rem 1rem;background-color:#9333ea;color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-error-btn:hover{background-color:#7e22ce}.merchant-not-found{min-height:100vh;background-color:#f9fafb;display:flex;align-items:center;justify-content:center;padding:1rem}.merchant-not-found-card{background-color:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a;padding:1.5rem;max-width:28rem;width:100%;text-align:center}.merchant-not-found-icon{width:3rem;height:3rem;color:#9ca3af;margin:0 auto 1rem}.merchant-not-found-title{font-size:1.25rem;font-weight:700;color:#111827;margin:0 0 .5rem}.merchant-not-found-message{color:#4b5563;margin:0 0 1rem}.merchant-not-found-btn{padding:.5rem 1rem;background-color:#4b5563;color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .2s}.merchant-not-found-btn:hover{background-color:#374151}.merchant-notification-banner{position:fixed;top:64px;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #00000026;cursor:pointer;z-index:999;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.merchant-notification-banner:hover{background:linear-gradient(135deg,#5a6fd8,#6a3f8f)}.notification-icon{width:24px;height:24px;flex-shrink:0;animation:ring 1s ease-in-out infinite}@keyframes ring{0%,to{transform:rotate(0)}10%,30%{transform:rotate(-15deg)}20%,40%{transform:rotate(15deg)}}.notification-content{flex:1;min-width:0}.notification-title{font-weight:600;font-size:14px;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-text{font-size:13px;opacity:.95;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-close{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff3;transition:all .2s}.notification-close:hover{background:#ffffff4d;transform:scale(1.1)}.notification-close svg{width:16px;height:16px}@media (max-width: 768px){.merchant-notification-banner{top:56px;padding:14px 16px}.notification-icon{width:20px;height:20px}.notification-title{font-size:13px}.notification-text{font-size:12px}.notification-close{width:24px;height:24px}.notification-close svg{width:14px;height:14px}}.merchant-dashboard:has(.merchant-notification-banner) .merchant-main{padding-top:72px}@media (max-width: 768px){.merchant-dashboard:has(.merchant-notification-banner) .merchant-main{padding-top:64px}}.merchant-not-assigned{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.merchant-not-assigned-card{background:#fff;border-radius:16px;padding:40px;max-width:600px;width:100%;box-shadow:0 8px 32px #0000001a;text-align:center}.merchant-not-assigned-icon{width:80px;height:80px;margin:0 auto 24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.merchant-not-assigned-icon svg{width:40px;height:40px}.merchant-not-assigned-title{font-size:24px;font-weight:600;color:#333;margin-bottom:16px}.merchant-not-assigned-content{margin-bottom:32px}.merchant-not-assigned-message{font-size:16px;color:#666;margin-bottom:24px;line-height:1.6}.merchant-not-assigned-steps{background:#f5f5f5;border-radius:12px;padding:24px;text-align:left;margin-bottom:24px}.merchant-not-assigned-steps h3{font-size:16px;font-weight:600;color:#333;margin-bottom:16px}.merchant-not-assigned-steps ol{margin:0;padding-left:20px}.merchant-not-assigned-steps li{font-size:15px;color:#666;margin-bottom:12px;line-height:1.6}.merchant-not-assigned-steps li:last-child{margin-bottom:0}.merchant-not-assigned-steps strong{color:#667eea;font-weight:600}.merchant-not-assigned-info{background:#fff3e0;border-left:4px solid #f57c00;border-radius:8px;padding:16px;text-align:left}.merchant-not-assigned-info p{font-size:14px;color:#666;margin:8px 0}.merchant-not-assigned-info strong{color:#333;font-weight:600}.merchant-not-assigned-actions{display:flex;gap:12px;justify-content:center}.merchant-not-assigned-actions .merchant-refresh-btn,.merchant-not-assigned-actions .merchant-to-customer-btn{flex:1;max-width:200px;padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.merchant-not-assigned-actions .merchant-refresh-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.merchant-not-assigned-actions .merchant-refresh-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.merchant-not-assigned-actions .merchant-to-customer-btn{background:#fff;color:#666;border:1px solid #e0e0e0}.merchant-not-assigned-actions .merchant-to-customer-btn:hover{background:#f5f5f5;border-color:#d0d0d0}.merchant-to-customer-icon{width:16px;height:16px;object-fit:contain}@media (max-width: 768px){.merchant-not-assigned-card{padding:24px}.merchant-not-assigned-title{font-size:20px}.merchant-not-assigned-message{font-size:14px}.merchant-not-assigned-steps{padding:16px}.merchant-not-assigned-actions{flex-direction:column}.merchant-not-assigned-actions .merchant-refresh-btn,.merchant-not-assigned-actions .merchant-logout-btn{max-width:100%}}.ps-container{width:100%;min-height:100vh;background-color:#f5f5f5;display:flex;flex-direction:column;align-items:center;margin:0 auto;box-sizing:border-box}.ps-loading-container,.ps-error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.ps-spinner{border:4px solid rgba(255,255,255,.3);border-top:4px solid #fff;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}.ps-error-message{font-size:18px;margin:20px 0}.ps-button{padding:12px 24px;background:#fff;color:#667eea;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.ps-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.ps-header{background:#fffffff2;border-radius:12px;padding:24px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 12px #0000001a}.ps-header-left{flex:1}.ps-title{font-size:28px;font-weight:700;color:#2d3748;margin:0 0 8px}.ps-welcome-text{font-size:16px;color:#718096;margin:0}.ps-header-right{display:flex;align-items:center;gap:16px}.ps-date{font-size:14px;color:#718096;padding:8px 16px;background:#f7fafc;border-radius:6px}.ps-inactive-badge{padding:8px 16px;background:#fed7d7;color:#c53030;border-radius:6px;font-size:14px;font-weight:600}.ps-logout-button{padding:10px 20px;background:#e53e3e;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.ps-logout-button:hover{background:#c53030;transform:translateY(-2px);box-shadow:0 4px 8px #e53e3e4d}.ps-warning-banner{background:#fed7d7;color:#c53030;padding:16px 24px;border-radius:8px;margin-bottom:20px;font-size:16px;text-align:center;font-weight:600;border:2px solid #fc8181}.tab-navigation{display:flex;width:100%;max-width:100vw;border-bottom:1px solid #e0e0e0;position:sticky;top:0;z-index:10;box-shadow:0 1px 3px #0000001a;background:#fff;box-sizing:border-box}.tab-navigation button:focus,.tab-navigation button:focus-visible{outline:none}.tab-navigation button{-webkit-tap-highlight-color:transparent}.dashboard-content{flex:1;padding:1rem 0;overflow-y:auto;display:flex;flex-direction:column;align-items:center;width:100%;box-sizing:border-box}@media (max-width: 768px){.ps-container{display:flex;flex-direction:column}.tab-navigation{flex-wrap:wrap}.dashboard-content{flex:1;padding:.5rem 0}}.issue-point-card{max-width:100%;width:100%;margin:0 auto;padding:0 1rem 2rem;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.inventory-summary{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:0;align-items:center;margin:0 auto 32px;padding:16px 12px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;overflow:hidden;box-sizing:border-box;width:100%;max-width:720px}.inventory-card{text-align:center;padding:12px 8px;flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff}.inventory-icon{width:28px;height:28px;opacity:.9;filter:brightness(0) invert(1)}.inventory-label{font-size:12px;opacity:.85;white-space:nowrap;min-width:80px}.inventory-value{font-size:24px;font-weight:700;line-height:1}.inventory-divider{width:1px;height:60px;background-color:#ffffff4d;margin:0 4px}.issued-card-display{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;padding:24px;margin:0 auto 32px;width:100%;max-width:720px;box-sizing:border-box}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.card-header h3{font-size:20px;font-weight:700;color:#2d3748;margin:0}.clear-button{padding:10px 20px;background:#718096;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.clear-button:hover{background:#4a5568;transform:translateY(-2px)}.card-details{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;overflow:hidden}.card-info{display:flex;flex-direction:column;gap:12px;min-width:0}.info-row{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.info-label{font-size:13px;color:#718096;min-width:50px;flex-shrink:0}.info-value{font-size:15px;font-weight:600;color:#2d3748;word-break:break-word;flex-shrink:1;min-width:0}.card-number{font-family:Courier New,monospace;color:#667eea;font-size:14px;word-break:break-all}.qr-code-display{display:flex;flex-direction:column;align-items:center;gap:12px;min-width:0;justify-content:center;padding:12px;background:#f8f8f8;border-radius:8px}.qr-code-image{max-width:100%;width:150px;height:150px;border:3px solid #667eea;border-radius:8px;background:#fff;padding:4px;object-fit:contain}.qr-hint{font-size:12px;color:#718096;margin:0;text-align:center}.card-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px;overflow:hidden}.download-button,.print-button{padding:12px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.download-button{background:#48bb78;color:#fff}.download-button:hover{background:#38a169;transform:translateY(-2px);box-shadow:0 4px 12px #48bb784d}.print-button{background:#cbd5e0;color:#718096}.print-button:not(:disabled):hover{background:#a0aec0;transform:translateY(-2px)}.print-button:disabled{cursor:not-allowed;opacity:.6}.print-button.bluetooth{background:#667eea;color:#fff}.print-button.bluetooth:not(:disabled):hover{background:#5568d3}.printer-status{background:#c6f6d5;color:#22543d;padding:12px;border-radius:8px;font-size:13px;margin-bottom:16px;text-align:center;overflow:hidden}.reminder-box{background:#fff5e6;border:2px solid #f6ad55;border-radius:8px;padding:12px;display:flex;gap:10px;align-items:flex-start;overflow:hidden}.reminder-icon{font-size:20px;margin:0;flex-shrink:0}.reminder-text{flex:1;font-size:13px;color:#744210;margin:0;line-height:1.5;word-break:break-word;min-width:0}@media (max-width: 768px){.inventory-summary{grid-template-columns:1fr auto 1fr auto 1fr;padding:16px}.inventory-card{padding:8px 4px}.inventory-icon{width:24px;height:24px}.inventory-value{font-size:18px}.inventory-label{font-size:11px;min-width:60px}.card-details{grid-template-columns:1fr;gap:12px}.qr-code-image{width:120px;height:120px}.card-actions{grid-template-columns:1fr 1fr}.download-button,.print-button{font-size:12px;padding:10px 8px}.reminder-box{padding:10px}.reminder-icon{font-size:18px}.reminder-text{font-size:12px}}@media (max-width: 480px){.inventory-summary{grid-template-columns:1fr auto 1fr auto 1fr;padding:12px;gap:0}.inventory-icon{width:20px;height:20px}.inventory-value{font-size:16px}.inventory-label{font-size:10px;min-width:50px}.card-details{grid-template-columns:1fr}.qr-code-image{width:100px;height:100px}.card-actions{grid-template-columns:1fr;gap:8px}.download-button,.print-button{font-size:11px;padding:10px 6px}.info-label{font-size:12px}.info-value{font-size:13px}}.issue-form{max-width:720px;margin:0 auto;padding:0;box-sizing:border-box;width:100%}.form-section{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px;overflow:hidden}.hint{font-size:12px;color:#718096}.error-message{background:#fed7d7;color:#c53030;padding:10px 12px;border-radius:8px;font-size:13px;border:1px solid #fc8181;overflow:hidden;word-break:break-word}.success-message{background:#c6f6d5;color:#22543d;padding:10px 12px;border-radius:8px;font-size:13px;border:1px solid #9ae6b4;overflow:hidden;word-break:break-word}@media (max-width: 768px){.card-details{grid-template-columns:1fr}.qr-code-image{width:200px;height:200px}.card-actions{flex-direction:column}.amount-input-wrapper{flex-direction:column;align-items:stretch}.input-suffix{text-align:center;border-top:1px solid #e2e8f0}}.direct-sale{max-width:100%;width:100%;margin:0 auto;padding:0 1rem 2rem;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.section-title{font-size:24px;font-weight:700;color:#2d3748;margin:0 auto 24px;display:flex;align-items:center;gap:8px;justify-content:center;text-align:center;width:100%;max-width:720px}.seller-inventory{background:linear-gradient(135deg,#48bb78,#38a169);padding:24px 16px;border-radius:12px;color:#fff;text-align:center;margin:0 auto 32px;width:100%;max-width:720px;box-sizing:border-box;overflow:hidden}.inventory-label{font-size:14px;opacity:.9;margin-bottom:8px}.inventory-amount{font-size:48px;font-weight:700;margin-bottom:4px}.inventory-hint{font-size:14px;opacity:.8}.form-section{display:flex;flex-direction:column;gap:24px;width:100%;max-width:720px;margin:0 auto;box-sizing:border-box}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#2d3748}.input-group{display:flex;gap:12px}.input-group input{flex:1;padding:14px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:all .3s ease}.input-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.input-group input:disabled{background:#f7fafc;cursor:not-allowed}.search-button{padding:14px 28px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .3s ease}.search-button:hover:not(:disabled){background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.search-button:disabled{opacity:.6;cursor:not-allowed}.customer-info{background:#c6f6d5;border:2px solid #9ae6b4;border-radius:8px;padding:16px;overflow:hidden;box-sizing:border-box}.customer-name{font-size:16px;color:#22543d;margin-bottom:8px;word-break:break-word;overflow:hidden}.customer-balance{font-size:14px;color:#276749;word-break:break-word;overflow:hidden}.success-box{background:#c6f6d5;border-color:#9ae6b4}.amount-input-wrapper{display:flex;align-items:center;gap:12px;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:4px;transition:all .3s ease}.amount-input-wrapper:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.amount-input-wrapper input{flex:1;padding:12px 16px;border:none;background:transparent;font-size:18px;font-weight:600;color:#2d3748}.amount-input-wrapper input:focus{outline:none}.input-suffix{padding:12px 16px;font-size:14px;font-weight:600;color:#667eea;white-space:nowrap}.balance-check{margin-top:8px}.balance-ok{color:#22543d;font-size:14px;font-weight:600}.balance-insufficient{color:#c53030;font-size:14px;font-weight:600}.hint{font-size:12px;color:#718096;margin-top:4px}.error-message{background:#fed7d7;color:#c53030;padding:10px 12px;border-radius:8px;font-size:13px;border:1px solid #fc8181;overflow:hidden;word-break:break-word;box-sizing:border-box}.success-message{background:#c6f6d5;color:#22543d;padding:10px 12px;border-radius:8px;font-size:13px;border:1px solid #9ae6b4;overflow:hidden;word-break:break-word;box-sizing:border-box}.submit-button{width:100%;padding:14px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-sizing:border-box}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.submit-button:disabled{opacity:.6;cursor:not-allowed}.info-box{background:#ebf8ff;border:2px solid #90cdf4;border-radius:8px;padding:16px 12px;overflow:hidden;box-sizing:border-box;text-align:center}.info-title{font-size:14px;font-weight:700;color:#2c5282;margin:0 0 10px;text-align:center}.info-list{margin:0 auto;padding-left:0;color:#2c5282;list-style:none;overflow:hidden;text-align:center}.info-list li{margin-bottom:6px;line-height:1.4;font-size:13px;word-break:break-word}@media (max-width: 768px){.input-group{flex-direction:column}.search-button{width:100%}.amount-input-wrapper{flex-direction:column;align-items:stretch}.input-suffix{text-align:center;border-top:1px solid #e2e8f0}.inventory-amount{font-size:36px}}.issuance-history{max-width:100%;width:100%;margin:0 auto;padding:0 1rem 2rem;box-sizing:border-box;display:flex;flex-direction:column;align-items:center}.history-header{display:flex;justify-content:space-between;align-items:center;margin:0 auto 24px;width:100%;max-width:720px;box-sizing:border-box}.history-header h2{font-size:24px;font-weight:700;color:#2d3748;margin:0}.refresh-button{padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.refresh-button:hover{background:#5a67d8;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin:0 auto 32px;width:100%;max-width:720px;box-sizing:border-box}.stat-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;border-left:4px solid;transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.stat-card.blue{border-color:#4299e1}.stat-card.green{border-color:#48bb78}.stat-card.purple{border-color:#9f7aea}.stat-card.orange{border-color:#ed8936}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.card-icon{font-size:24px}.card-title{font-size:14px;color:#718096;font-weight:600}.card-content{display:flex;align-items:baseline;gap:8px}.card-content .value{font-size:32px;font-weight:700;color:#2d3748}.card-content .unit{font-size:16px;color:#718096}.total-stats{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:24px 16px;margin:0 auto 32px;width:100%;max-width:720px;box-sizing:border-box;overflow:hidden}.total-stats h3{color:#fff;font-size:20px;font-weight:700;margin:0 0 20px}.total-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.total-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;padding:16px;text-align:center}.total-label{font-size:12px;color:#ffffffe6;margin-bottom:8px}.total-value{font-size:24px;font-weight:700;color:#fff}.filter-section{display:flex;gap:16px;margin:0 auto 24px;flex-wrap:wrap;width:100%;max-width:720px;box-sizing:border-box}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:10px 20px;background:#f7fafc;color:#4a5568;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.filter-btn:hover{background:#e2e8f0}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.search-box{flex:1;min-width:250px}.search-input{width:100%;padding:10px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .3s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.records-section{width:100%;max-width:720px;margin:0 auto;box-sizing:border-box}.records-section h3{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 16px}.records-table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 8px #0000001a;box-sizing:border-box;width:100%}.records-table{width:100%;border-collapse:collapse;background:#fff}.records-table thead{background:#f7fafc}.records-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:#4a5568;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.records-table td{padding:16px;border-bottom:1px solid #e2e8f0}.records-table tbody tr{transition:background .2s ease}.records-table tbody tr:hover{background:#f7fafc}.record-type{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600}.record-type.point_card{background:#bee3f8;color:#2c5282}.record-type.direct_sale{background:#c6f6d5;color:#22543d}.card-info,.customer-info{display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden}.card-number,.customer-name{font-weight:600;color:#2d3748;word-break:break-word;overflow:hidden}.card-id,.customer-id{font-size:12px;color:#718096;font-family:Courier New,monospace;word-break:break-all;overflow:hidden}.points-cell,.amount-cell{font-weight:600;color:#2d3748}.time-cell{font-size:14px;color:#718096}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.active,.status-badge.completed{background:#c6f6d5;color:#22543d}.status-badge.inactive,.status-badge.pending{background:#fed7d7;color:#c53030}.records-empty{text-align:center;padding:60px 20px;color:#718096}@media (max-width: 768px){.stats-cards{grid-template-columns:1fr}.filter-section{flex-direction:column}.filter-buttons{width:100%}.filter-btn{flex:1}.records-table{font-size:14px}.records-table th,.records-table td{padding:12px 8px}.card-content .value{font-size:24px}.total-value{font-size:20px}.total-cards{grid-template-columns:1fr}}@media (max-width: 480px){.history-header{flex-direction:column;gap:12px;align-items:stretch}.refresh-button{width:100%}.card-content .value{font-size:20px}.total-value{font-size:18px}}.cash-submission{max-width:1000px;margin:0 auto}.cash-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.summary-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;text-align:center;border-left:4px solid}.summary-card.total{border-color:#4299e1}.summary-card.submitted{border-color:#48bb78}.summary-card.pending{border-color:#ed8936}.summary-label{font-size:14px;color:#718096;margin-bottom:8px}.summary-value{font-size:28px;font-weight:700;color:#2d3748}.summary-value.highlight{color:#ed8936}.available-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{font-size:18px;font-weight:700;color:#2d3748;margin:0}.select-all-btn{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.select-all-btn:hover{background:#5a67d8;transform:translateY(-2px)}.records-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.record-item{display:flex;align-items:center;gap:16px;padding:16px;border-bottom:1px solid #e2e8f0;cursor:pointer;transition:all .2s ease}.record-item:last-child{border-bottom:none}.record-item:hover{background:#f7fafc}.record-item.selected{background:#ebf8ff;border-color:#90cdf4}.record-checkbox{flex-shrink:0}.record-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer}.record-info{flex:1;display:flex;flex-direction:column;gap:4px}.record-type{font-size:14px;font-weight:600;color:#2d3748}.record-details{font-size:13px;color:#718096}.record-time{font-size:12px;color:#a0aec0}.record-amount{font-size:18px;font-weight:700;color:#2d3748;white-space:nowrap}.records-empty{text-align:center;padding:60px 20px;color:#718096;background:#fff;border-radius:8px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-message{font-size:16px;margin:0}.submission-panel{background:#f7fafc;border:2px solid #e2e8f0;border-radius:12px;padding:24px;margin-top:16px}.selected-summary{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff;border-radius:8px;margin-bottom:20px}.selected-count{font-size:16px;color:#4a5568;font-weight:600}.selected-amount{font-size:24px;font-weight:700;color:#667eea}.note-group{margin-bottom:20px}.note-group label{display:block;font-size:14px;font-weight:600;color:#2d3748;margin-bottom:8px}.note-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;transition:all .3s ease}.note-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.char-count{font-size:12px;color:#a0aec0;text-align:right;margin-top:4px}.submit-cash-btn{width:100%;padding:16px 32px;background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;border:none;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease}.submit-cash-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #48bb7866}.submit-cash-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid #fc8181;margin-bottom:16px}.success-message{background:#c6f6d5;color:#22543d;padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid #9ae6b4;margin-bottom:16px}.pending-section,.confirmed-section{margin-top:32px}.pending-section h3,.confirmed-section h3{font-size:18px;font-weight:700;color:#2d3748;margin:0 0 16px}.pending-list,.confirmed-list{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.pending-item,.confirmed-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e2e8f0}.pending-item:last-child,.confirmed-item:last-child{border-bottom:none}.pending-info,.confirmed-info{flex:1;display:flex;flex-direction:column;gap:4px}.pending-amount,.confirmed-amount{font-size:18px;font-weight:700;color:#2d3748}.pending-time,.confirmed-time,.confirmed-receiver{font-size:13px;color:#718096}.pending-note{font-size:13px;color:#4a5568;font-style:italic}.pending-status,.confirmed-status{flex-shrink:0}.status-badge{display:inline-block;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600}.status-badge.pending{background:#fed7d7;color:#c53030}.status-badge.confirmed{background:#c6f6d5;color:#22543d}@media (max-width: 768px){.cash-summary{grid-template-columns:1fr}.record-item{flex-wrap:wrap}.record-amount{width:100%;text-align:right;margin-top:8px}.selected-summary{flex-direction:column;gap:8px}.summary-value{font-size:24px}}.initial-setup-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.initial-setup-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;padding:40px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.setup-header{text-align:center;margin-bottom:30px}.setup-header h1{font-size:28px;font-weight:700;color:#2d3748;margin-bottom:8px}.welcome-text{font-size:16px;color:#718096;margin:0}.progress-indicator{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding:0 20px}.step{display:flex;flex-direction:column;align-items:center;flex:1}.step-circle{width:50px;height:50px;border-radius:50%;background-color:#e2e8f0;color:#a0aec0;display:flex;justify-content:center;align-items:center;font-size:20px;font-weight:700;transition:all .3s ease;margin-bottom:8px}.step.active .step-circle{background-color:#667eea;color:#fff;box-shadow:0 4px 12px #667eea66}.step.completed .step-circle{background-color:#48bb78;color:#fff}.step-label{font-size:13px;color:#718096;font-weight:500;text-align:center}.step-line{flex:1;height:2px;background-color:#e2e8f0;margin:0 10px 25px}.setup-form{margin-top:20px}.form-section h2{font-size:22px;font-weight:600;color:#2d3748;margin-bottom:8px}.section-description{font-size:14px;color:#718096;margin-bottom:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:600;color:#4a5568;margin-bottom:8px}.form-group input{width:100%;padding:12px 16px;font-size:15px;border:2px solid #e2e8f0;border-radius:8px;transition:all .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.field-hint{display:block;font-size:12px;color:#a0aec0;margin-top:6px}.pin-input{font-size:24px;letter-spacing:8px;text-align:center;font-weight:600}.btn-primary{width:100%;padding:14px 24px;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:24px}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background-color:#fed7d7;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;font-size:14px;animation:shake .5s ease}.error-icon{margin-right:8px;font-size:18px}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.security-tips{background-color:#f7fafc;border-left:4px solid #667eea;padding:16px;border-radius:8px;margin-top:24px}.security-tips h3{font-size:16px;font-weight:600;color:#2d3748;margin:0 0 12px}.security-tips ul{margin:0;padding-left:20px}.security-tips li{font-size:13px;color:#4a5568;margin-bottom:8px;line-height:1.5}.security-tips li:last-child{margin-bottom:0}.loading{text-align:center;font-size:18px;color:#fff;padding:40px}@media (max-width: 600px){.initial-setup-card{padding:30px 20px}.setup-header h1{font-size:24px}.progress-indicator{padding:0 10px}.step-circle{width:40px;height:40px;font-size:16px}.step-label{font-size:11px}.form-section h2{font-size:20px}}.password-setup-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.password-setup-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;padding:2.5rem;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.setup-header{text-align:center;margin-bottom:2rem}.setup-logo{font-size:3.5rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.setup-title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0 0 .5rem}.setup-subtitle{font-size:.95rem;color:#6b7280;margin:0}.steps-indicator{display:flex;align-items:center;justify-content:space-between;margin-bottom:2.5rem;padding:0 1rem}.step{display:flex;flex-direction:column;align-items:center;position:relative;flex:0 0 auto}.step-number{width:40px;height:40px;border-radius:50%;background:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;transition:all .3s ease;margin-bottom:.5rem}.step-label{font-size:.8rem;color:#9ca3af;font-weight:500;transition:all .3s ease;white-space:nowrap}.step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea66}.step.active .step-label{color:#667eea;font-weight:600}.step.completed .step-number{background:#10b981;color:#fff}.step.completed .step-label{color:#10b981}.step-divider{flex:1;height:2px;background:#e5e7eb;margin:0 .5rem 1.5rem;position:relative;overflow:hidden}.step.completed+.step-divider{background:#10b981}.setup-form{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.form-section{margin-bottom:1.5rem}.section-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.section-description{font-size:.9rem;color:#6b7280;margin:0 0 1.5rem;line-height:1.5}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.9rem;font-weight:600;color:#374151;margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-input:disabled{background:#f3f4f6;cursor:not-allowed}.form-input.pin-input{text-align:center;font-size:1.5rem;letter-spacing:.5rem;font-weight:600}.input-hint{font-size:.8rem;color:#6b7280;margin-top:.4rem}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.submit-button{width:auto;display:block;margin:1rem auto 0;min-width:220px;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 600px){.submit-button{width:100%;min-width:0;margin:.75rem 0 0}}.completion-section{text-align:center;padding:2rem 0;animation:fadeIn .5s ease-out}.success-icon{font-size:4rem;margin-bottom:1rem;animation:bounceIn .6s ease-out}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1)}}.success-title{font-size:1.5rem;font-weight:700;color:#10b981;margin:0 0 .5rem}.success-message{font-size:1rem;color:#6b7280;margin:0 0 1rem}.redirect-message{font-size:.9rem;color:#9ca3af;margin:0 0 1.5rem}.loading-spinner{display:flex;justify-content:center;align-items:center;padding:2rem}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 640px){.password-setup-card{padding:1.5rem}.setup-title{font-size:1.5rem}.setup-subtitle{font-size:.85rem}.steps-indicator{padding:0}.step-number{width:36px;height:36px;font-size:1rem}.step-label{font-size:.7rem}.step-divider{margin:0 .25rem 1.5rem}.section-title{font-size:1.1rem}.section-description{font-size:.85rem}.form-input{padding:.65rem .875rem;font-size:.95rem}.form-input.pin-input{font-size:1.3rem;letter-spacing:.3rem}.success-icon{font-size:3rem}.success-title{font-size:1.3rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}button:hover{opacity:.9;transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}input:focus,textarea:focus,select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.spinner{animation:spin 1s linear infinite}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*,*:before,*:after{box-sizing:inherit}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#html5-qrcode-anchor-scan-type-change,.html5-qrcode-element[style*="color: rgb(255, 0, 0)"]{display:none!important}#qr-reader>div[style*="color: rgb(255, 0, 0)"],#qr-reader>div[style*="color:#ff0000"]{display:none!important}@keyframes slideDown{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.customer-notification-banner{animation:slideDown .3s ease-out;transition:all .3s ease}.customer-notification-banner:hover{transform:translate(-50%) translateY(-2px);box-shadow:0 6px 12px #00000026}
