@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size:12px;--rc-drag-handle-mobile-size:24px;--rc-drag-handle-bg-colour:#0003;--rc-drag-bar-size:6px;--rc-border-color:#ffffffb3;--rc-focus-color:#08f}.ReactCrop{cursor:crosshair;display:inline-block;max-width:100%;position:relative}.ReactCrop *,.ReactCrop :after,.ReactCrop :before{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{max-height:inherit;overflow:hidden}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-height:inherit;max-width:100%}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{bottom:0;height:calc(100% + .5px);left:0;pointer-events:none;position:absolute;right:0;top:0;width:calc(100% + .5px)}.ReactCrop__crop-selection{cursor:move;left:0;position:absolute;top:0;-webkit-transform:translateZ(0);transform:translateZ(0)}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);bottom:-1px;content:"";left:-1px;opacity:.3;pointer-events:none;position:absolute;right:-1px;top:-1px}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed #fff}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(90deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0),linear-gradient(180deg,#fff 50%,#444 0);background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;background-size:10px 1px,10px 1px,1px 10px,1px 10px;color:#fff}.ReactCrop__crop-selection:focus{outline:2px solid #08f;outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{background-color:#fff6;content:"";display:block;position:absolute}.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-vt:before{height:100%;width:1px}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:after,.ReactCrop__rule-of-thirds-hz:before{height:1px;width:100%}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{background-color:#0003;background-color:var(--rc-drag-handle-bg-colour);border:1px solid #ffffffb3;border:1px solid var(--rc-border-color);height:12px;height:var(--rc-drag-handle-size);position:absolute;width:12px;width:var(--rc-drag-handle-size)}.ReactCrop__drag-handle:focus{background:#08f;background:var(--rc-focus-color)}.ReactCrop .ord-nw{cursor:nw-resize;left:0}.ReactCrop .ord-n,.ReactCrop .ord-nw{top:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop .ord-n{cursor:n-resize;left:50%}.ReactCrop .ord-ne{cursor:ne-resize;top:0}.ReactCrop .ord-e,.ReactCrop .ord-ne{right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%)}.ReactCrop .ord-e{cursor:e-resize;top:50%}.ReactCrop .ord-se{bottom:0;cursor:se-resize;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%)}.ReactCrop .ord-s{cursor:s-resize;left:50%}.ReactCrop .ord-s,.ReactCrop .ord-sw{bottom:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%)}.ReactCrop .ord-sw{cursor:sw-resize;left:0}.ReactCrop .ord-w{cursor:w-resize;left:0;top:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%)}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{height:6px;height:var(--rc-drag-bar-size);left:0;top:0;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:100%}.ReactCrop__drag-bar.ord-e{height:100%;right:0;top:0;-webkit-transform:translate(50%);transform:translate(50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop__drag-bar.ord-s{bottom:0;height:6px;height:var(--rc-drag-bar-size);left:0;-webkit-transform:translateY(50%);transform:translateY(50%);width:100%}.ReactCrop__drag-bar.ord-w{height:100%;left:0;top:0;-webkit-transform:translate(-50%);transform:translate(-50%);width:6px;width:var(--rc-drag-bar-size)}.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w,.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle{display:none}@media (pointer:coarse){.ReactCrop .ord-e,.ReactCrop .ord-n,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{height:24px;height:var(--rc-drag-handle-mobile-size);width:24px;width:var(--rc-drag-handle-mobile-size)}}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#3b82f6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--white:#fff;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius:8px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:#f9fafb;background-color:var(--gray-50);color:#111827;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:#fff;background:var(--white);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);justify-content:space-between;padding:1rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-logo{align-items:center;display:flex}.header-logo{color:#111827;color:var(--gray-900);gap:.75rem;text-decoration:none}.header-logo svg{color:#2563eb;color:var(--primary);height:32px;width:32px}.header-logo h1{font-size:1.25rem;font-weight:700}.header-nav{gap:1rem}.header-nav,.header-user{align-items:center;display:flex}.header-user{gap:.75rem}.header-username{color:#4b5563;color:var(--gray-600);font-size:.875rem}.main{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.auth-container{margin:4rem auto;max-width:400px}.auth-card{background:#fff;background:var(--white);border-radius:8px;border-radius:var(--radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);padding:2rem}.auth-header{margin-bottom:2rem;text-align:center}.auth-header h1{color:#111827;color:var(--gray-900);font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.auth-header p{color:#6b7280;color:var(--gray-500)}.auth-form{gap:1.25rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius);font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.select-with-add{display:flex;gap:.5rem}.select-with-add input,.select-with-add select{flex:1 1}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s}.btn-primary{background:#2563eb;background:var(--primary);color:#fff;color:var(--white)}.btn-primary:hover{background:#1d4ed8;background:var(--primary-dark)}.btn-secondary{background:#f3f4f6;background:var(--gray-100);color:#374151;color:var(--gray-700)}.btn-secondary:hover{background:#e5e7eb;background:var(--gray-200)}.btn-danger{background:#ef4444;background:var(--danger);color:var(--white)}.btn-danger:hover{background:#dc2626}.btn-outline{background:#0000;border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#374151;color:var(--gray-700)}.btn-outline:hover{background:#f9fafb;background:var(--gray-50)}.btn-sm{font-size:.75rem;padding:.5rem 1rem}.btn-lg{font-size:1rem;padding:1rem 2rem}.btn-block{width:100%}.btn:disabled{cursor:not-allowed;opacity:.6}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem;font-weight:700}.dashboard-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;background:var(--white);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow);padding:1.5rem}.stat-card h3{color:#6b7280;color:var(--gray-500);font-size:.875rem;font-weight:500;margin-bottom:.5rem}.stat-card .value{color:#111827;color:var(--gray-900);font-size:1.75rem;font-weight:700}.receipts-container{background:#fff;background:var(--white);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow);overflow:hidden}.receipts-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);padding:1.5rem}.receipts-header h2{font-size:1.25rem;font-weight:600}.receipts-table{border-collapse:collapse;width:100%}.receipts-table td,.receipts-table th{padding:1rem 1.5rem;text-align:left}.receipts-table th{background:#f9fafb;background:var(--gray-50);color:#6b7280;color:var(--gray-500);font-size:.75rem;font-weight:600;text-transform:uppercase}.receipts-table tbody tr{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--gray-100);transition:background .2s}.receipts-table tbody tr:hover{background:#f9fafb;background:var(--gray-50)}.receipts-table .amount{color:#10b981;color:var(--success);font-weight:600}.receipts-table .hash{color:#6b7280;color:var(--gray-500);font-family:monospace;font-size:.75rem;max-width:150px;overflow:hidden;text-overflow:ellipsis}.receipts-table .payment-method{border-radius:999px;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .75rem;text-transform:capitalize}.payment-method.cash{background:#dbeafe;color:#1d4ed8}.payment-method.electronic{background:#d1fae5;color:#059669}.pagination,.receipts-actions{display:flex;gap:.5rem}.pagination{align-items:center;justify-content:center;padding:1.5rem}.pagination button{background:#fff;background:var(--white);border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--radius);cursor:pointer;padding:.5rem 1rem;transition:all .2s}.pagination button:hover:not(:disabled){background:#f9fafb;background:var(--gray-50)}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination .page-info{color:#6b7280;color:var(--gray-500);font-size:.875rem;padding:0 1rem}.receipt-detail{margin:0 auto;max-width:800px}.receipt-detail-header{background:linear-gradient(135deg,#2563eb,#1d4ed8);background:linear-gradient(135deg,var(--primary) 0,var(--primary-dark) 100%);color:#fff;color:var(--white);padding:2rem}.receipt-detail-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.receipt-detail-header .receipt-id{font-size:.875rem;opacity:.8}.receipt-detail-body{padding:2rem}.receipt-detail-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.receipt-detail-item{display:flex;flex-direction:column;gap:.25rem}.receipt-detail-item label{color:#6b7280;color:var(--gray-500);font-size:.75rem;font-weight:500;text-transform:uppercase}.receipt-detail-item .value{color:#111827;color:var(--gray-900);font-size:1rem;font-weight:600}.receipt-detail-item.amount .value{color:#10b981;color:var(--success);font-size:1.5rem}.receipt-hash{background:#f9fafb;background:var(--gray-50);border-radius:8px;border-radius:var(--radius);margin-bottom:2rem;padding:1.5rem}.receipt-hash h3{color:#374151;color:var(--gray-700);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.receipt-hash code{color:#4b5563;color:var(--gray-600);font-family:monospace;font-size:.875rem;word-break:break-all}.receipt-photo{margin-top:1.5rem}.receipt-photo img{border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow);max-width:100%}.receipt-detail-actions{background:#f9fafb;background:var(--gray-50);border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:1rem;padding:1.5rem 2rem}.public-profile{margin:0 auto;max-width:900px}.public-header{margin-bottom:2rem;text-align:center}.public-header h1{font-size:2rem;font-weight:700;margin-bottom:.5rem}.public-header p{color:#6b7280;color:var(--gray-500)}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;background:var(--white);border-radius:8px;border-radius:var(--radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:#9ca3af;color:var(--gray-400);cursor:pointer;font-size:1.5rem;line-height:1;padding:0;position:absolute;right:15px;top:15px;z-index:10}.modal-close:hover{color:#4b5563;color:var(--gray-600)}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);justify-content:flex-end;padding:1.5rem}.alert,.modal-footer{display:flex;gap:.75rem}.alert{align-items:center;border-radius:8px;border-radius:var(--radius);margin-bottom:1rem;padding:1rem 1.5rem}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.loading{align-items:center;display:flex;justify-content:center;padding:3rem}.spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-top-color:#2563eb;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.empty-state{color:#6b7280;color:var(--gray-500);padding:4rem 2rem;text-align:center}.empty-state svg{color:#d1d5db;color:var(--gray-300);height:64px;margin-bottom:1rem;width:64px}.empty-state h3{color:#374151;color:var(--gray-700);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}@media (max-width:768px){.header{padding:1rem}.header-logo h1{font-size:1rem}.main{padding:1rem}.dashboard-header{align-items:flex-start;flex-direction:column;gap:1rem}.dashboard-stats{grid-template-columns:1fr}.receipts-table td,.receipts-table th{padding:.75rem}.receipts-header{flex-direction:column;gap:1rem}.receipt-detail-grid{grid-template-columns:1fr}.modal{margin:.5rem}}.admin-page{margin:0 auto;max-width:1200px;padding:2rem}.admin-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:2rem 0}.admin-section{background:var(--bg-card);border-radius:8px;border-radius:var(--radius);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;box-shadow:var(--shadow);margin-bottom:2rem;padding:1.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.section-header h2{color:var(--text-primary);font-size:1.25rem}.contacts-list{display:flex;flex-direction:column;gap:.5rem}.contact-item{align-items:center;background:var(--bg-hover);border-radius:8px;border-radius:var(--radius);display:flex;justify-content:space-between;padding:.75rem 1rem}.btn-delete{background:none;border:none;cursor:pointer;font-size:1.2rem;opacity:.6;transition:opacity .2s}.btn-delete:hover{opacity:1}.progress-bar{background:#e0e0e0;border-radius:10px;height:20px;margin-top:10px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);color:#fff;font-size:12px;height:100%;line-height:20px;text-align:center;transition:width .3s ease}.photo-container{display:flex;flex-direction:column;gap:10px}.btn-delete-photo{align-self:flex-start;background:#dc3545;border-radius:6px;padding:8px 16px}.btn-delete-photo:hover{background:#c82333}.success-message{background:#d4edda;border-radius:6px;color:#155724;margin-bottom:15px;padding:10px}.receipts-header{align-items:center;display:flex;justify-content:space-between}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{background:#e0e0e0!important}.btn-warning{color:#000}.filter-controls{align-items:center;display:flex;gap:10px}.filter-controls select{background:#fff}.filter-controls select,.filter-id-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:8px 12px}.filter-id-input{width:120px}.header-left{display:flex;flex-direction:column}.sort-hint{color:#999;font-size:12px;margin:0}.date-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:8px 12px}.status-badge{border-radius:4px;font-weight:600}.status-badge.valid{background:#d4edda;color:#155724}.status-badge.cancelled{background:#fff3cd;color:#856404}.receipt-actions{display:flex;justify-content:space-between;margin-bottom:20px}.receipt-document{background:#fff;border:2px solid #333;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:0 auto 30px;max-width:800px;padding:30px}.receipt-title-bar{align-items:center;border-bottom:3px solid #333;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.receipt-title-bar h1{color:#333;font-size:32px;font-weight:700;letter-spacing:4px;margin:0}.receipt-status{border-radius:4px;font-size:14px;font-weight:700;letter-spacing:1px;padding:6px 16px;text-transform:uppercase}.receipt-status.valid{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.receipt-status.cancelled{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.receipt-number{color:#666;font-size:18px;font-weight:600;margin-bottom:25px;text-align:center}.receipt-table{border-collapse:collapse;margin-bottom:25px;width:100%}.receipt-table td,.receipt-table th{border-bottom:1px solid #eee;padding:12px 15px;text-align:left}.receipt-table th{background:#f9f9f9;color:#555;font-weight:600;width:180px}.receipt-table td{color:#333}.receipt-table .amount-cell{color:#2e7d32;font-size:20px;font-weight:700}.receipt-table tr.cancel-row td,.receipt-table tr.cancel-row th{background:#fff3cd;color:#856404}.receipt-hash-section{background:#f5f5f5;border-radius:6px;margin-bottom:20px;padding:15px}.hash-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.receipt-hash{color:#666;display:block;font-family:Courier New,monospace;font-size:11px;word-break:break-all}.receipt-meta{border-top:1px solid #eee;color:#999;font-size:12px;padding-top:15px;text-align:center}.photo-section{background:#fff;border:1px solid #ddd;border-radius:8px;margin:0 auto;max-width:800px;padding:20px}.photo-section h3{color:#333;font-size:18px;margin:0 0 15px}.photo-buttons{display:flex;flex-wrap:wrap;gap:10px}.photo-buttons .btn{align-items:center;cursor:pointer;display:inline-flex;gap:5px}.totals-bar{background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-around;margin-bottom:20px;padding:15px 20px}.total-item{text-align:center}.total-item .total-label{color:#666;display:block;font-size:12px;margin-bottom:5px}.total-item .total-value{font-size:18px;font-weight:600}.total-item.income .total-value{color:#28a745}.total-item.withdrawals .total-value{color:#dc3545}.total-item.net .total-value{color:#333;font-size:22px;font-weight:700}.amount.withdrawal{color:#dc3545;font-weight:600}.btn-warning{background:#ffc107;border:1px solid #ffc107;color:#212529}.btn-warning:hover{background:#e0a800;border-color:#e0a800}@media (max-width:768px){.header{flex-wrap:wrap;gap:.5rem;padding:.75rem 1rem}.header h1{font-size:1.25rem}.header .user-info{font-size:.875rem}.dashboard-stats{gap:.75rem;grid-template-columns:1fr;padding:1rem}.action-buttons{flex-wrap:wrap;gap:.5rem}.action-buttons .btn{flex:1 1;font-size:.875rem;min-width:120px;padding:.5rem .75rem}.receipts-header{align-items:stretch;flex-direction:column;gap:1rem}.header-left h2{font-size:1.25rem}.filter-controls{flex-wrap:wrap;gap:.5rem}.filter-controls input,.filter-controls select{flex:1 1;font-size:.875rem;min-width:100px;padding:.5rem}.totals-bar{flex-direction:column;gap:.75rem;padding:1rem}.total-item .total-value{font-size:1.25rem}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}table{font-size:.875rem;min-width:600px}table td,table th{padding:.5rem}.pagination{flex-wrap:wrap;gap:.5rem;justify-content:center}.pagination .btn{font-size:.875rem;padding:.375rem .75rem}.modal{max-height:90vh;overflow-y:auto;padding:1rem;width:95%}.modal h2{font-size:1.25rem}.form-group{margin-bottom:1rem}.form-group label{font-size:.875rem}.form-group input,.form-group select,.form-group textarea{font-size:1rem;padding:.625rem}.modal-footer{flex-direction:column;gap:.5rem}.modal-footer .btn{width:100%}}@media (max-width:480px){.header{padding:.5rem}.header h1{font-size:1rem}.action-buttons .btn{min-width:100%}.filter-controls{flex-direction:column}.filter-controls input,.filter-controls select{width:100%}.stat-card{padding:.75rem}.stat-card h3{font-size:.75rem}.stat-card .value{font-size:1.25rem}}.receipts-actions{min-width:120px;white-space:nowrap}.receipts-actions .btn{font-size:.75rem;margin-right:.25rem;padding:.375rem .5rem}@media (max-width:768px){.receipts-actions{background:#fff;box-shadow:-2px 0 5px #0000001a;min-width:100px;position:-webkit-sticky;position:sticky;right:0;z-index:1}.receipts-actions .btn{display:inline-block;font-size:.8rem;margin-bottom:.25rem;padding:.5rem .625rem}table td:last-child,table th:last-child{background:#f9fafb;position:-webkit-sticky;position:sticky;right:0;z-index:1}}@media (max-width:480px){.receipts-actions{min-width:80px}.receipts-actions .btn{display:block;font-size:.7rem;margin:.125rem 0;min-width:50px;padding:.375rem .5rem}}@media (max-width:768px){.receipt-detail{padding:1rem}.receipt-actions{flex-direction:column;gap:.5rem}.receipt-actions .btn{justify-content:center;width:100%}.receipt-document{padding:1rem}.receipt-title-bar{flex-direction:column;gap:.5rem;text-align:center}.receipt-title-bar h1{font-size:24px}.receipt-number{font-size:14px}.receipt-table{font-size:12px}.receipt-table td,.receipt-table th{display:block;padding:8px 6px;width:100%}.receipt-table thead{display:none}.receipt-table tbody tr{border:1px solid #ddd;display:block;margin-bottom:1rem;padding:.5rem}.receipt-table tbody tr th{color:#666;font-weight:700}.receipt-table tbody tr td,.receipt-table tbody tr th{display:inline-block;padding:4px 0;width:auto}.receipt-table .amount-cell{font-size:18px}.receipt-hash-section{padding:10px}.receipt-hash{word-break:break-all}.receipt-hash,.receipt-meta{font-size:10px}.photo-section{padding:1rem}.photo-container{flex-direction:column}.photo-container img{max-width:100%}}@media (max-width:480px){.receipt-document{padding:.75rem}.receipt-title-bar h1{font-size:20px;letter-spacing:2px}.receipt-status{font-size:12px}.receipt-table .amount-cell{font-size:16px}}@media (max-width:768px){.modal-overlay{align-items:flex-start;overflow-y:auto;padding:.5rem}.modal{margin:.5rem 0;max-height:none;max-width:100%;padding:1rem;width:100%}.modal h2{font-size:1.25rem;margin-bottom:1rem;padding-right:2rem}.form-group{margin-bottom:.875rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-group input,.form-group select,.form-group textarea{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:.625rem;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.modal-footer{border-top:1px solid #eee;flex-direction:column;gap:.5rem;margin-top:1rem;padding-top:1rem}.modal-footer .btn{font-size:1rem;padding:.75rem 1rem;width:100%}.modal-close{font-size:1.5rem;height:2rem;right:.75rem;top:.75rem;width:2rem}datalist{max-height:150px;overflow-y:auto}}@media (max-width:480px){.modal{padding:.75rem}.modal h2{font-size:1.1rem}.form-group input,.form-group select,.form-group textarea{font-size:16px;padding:.5rem}.modal-footer .btn{padding:.625rem 1rem}}[data-theme=dark]{--primary:#3b82f6;--primary-dark:#2563eb;--gray-50:#1a1a2e;--gray-100:#16213e;--gray-200:#1f2937;--gray-300:#374151;--gray-400:#4b5563;--gray-500:#6b7280;--gray-600:#9ca3af;--gray-700:#d1d5db;--gray-800:#f3f4f6;--gray-900:#f9fafb;--white:#1a1a2e;background-color:#0f0f1a;color:#e5e7eb}[data-theme=dark] .admin-section,[data-theme=dark] .header,[data-theme=dark] .modal,[data-theme=dark] .photo-section,[data-theme=dark] .receipt-document,[data-theme=dark] .receipts-container,[data-theme=dark] .stat-card{background:#1a1a2e;border-color:#374151}[data-theme=dark] .admin-section,[data-theme=dark] .stat-card{background:#16213e}[data-theme=dark] table th{background:#1f3a5f}[data-theme=dark] table td{border-color:#374151}[data-theme=dark] .btn-secondary{background:#374151;border-color:#4b5563;color:#fff}[data-theme=dark] .btn-secondary:hover{background:#4b5563}[data-theme=dark] .date-input,[data-theme=dark] .filter-controls input,[data-theme=dark] .filter-controls select,[data-theme=dark] .filter-id-input,[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:#16213e;border-color:#374151;color:#e5e7eb}[data-theme=dark] .totals-bar{background:#16213e}[data-theme=dark] .summary-card{background:#16213e;border-color:#374151}[data-theme=dark] .summary-card h3{color:#9ca3af}[data-theme=dark] .summary-card .value{color:#e5e7eb}[data-theme=dark] .meta-item .meta-label{color:#9ca3af}[data-theme=dark] .receipts-actions{background:#1a1a2e}[data-theme=dark] .receipts-actions .btn-secondary{background:#374151;color:#fff}[data-theme=dark] .receipt-detail{background:#0f0f1a}[data-theme=dark] .receipt-document{background:linear-gradient(145deg,#1a1a2e,#16213e);border:1px solid #3b82f6;box-shadow:0 8px 32px #3b82f626}[data-theme=dark] .receipt-detail-header h1{color:#60a5fa}[data-theme=dark] .receipt-detail-item label{color:#94a3b8}[data-theme=dark] .receipt-detail-item .value{color:#f1f5f9;font-weight:600}[data-theme=dark] .receipt-title-bar{background:linear-gradient(90deg,#1e3a5f,#2563eb);border-bottom:2px solid #3b82f6}[data-theme=dark] .receipt-title-bar h1{color:#fff}[data-theme=dark] .receipt-number{color:#cbd5e1}[data-theme=dark] .receipt-status{color:#fff}[data-theme=dark] .receipt-status.valid{background:#059669;color:#fff}[data-theme=dark] .receipt-status.cancelled{background:#dc2626;color:#fff}[data-theme=dark] .meta{background:#16213e;border:1px solid #334155}[data-theme=dark] .meta-item .meta-label{color:#94a3b8}[data-theme=dark] .meta-item .meta-value{color:#e2e8f0}[data-theme=dark] .photo-section{background:#16213e;border:1px solid #334155}[data-theme=dark] .photo-section h3{color:#e2e8f0}[data-theme=dark] .receipt-actions{background:#1a1a2e;border-top:1px solid #334155}[data-theme=dark] .receipt-actions .btn{border-color:#475569}[data-theme=dark] .receipt-actions .btn-primary{background:#2563eb;border-color:#3b82f6}[data-theme=dark] .receipt-actions .btn-primary:hover{background:#1d4ed8}[data-theme=dark] .receipt-actions .btn-secondary{background:#334155;color:#e2e8f0}[data-theme=dark] .receipt-actions .btn-secondary:hover{background:#475569}[data-theme=dark] .btn-outline{background:#0000;border:1px solid #3b82f6;color:#60a5fa}[data-theme=dark] .btn-outline:hover{background:#1e3a8a;color:#93c5fd}@media (max-width:768px){.receipt-detail{padding:.5rem}.receipt-detail-grid{gap:.75rem;grid-template-columns:1fr}.receipt-detail-item{display:flex;flex-direction:column;gap:.25rem}.receipt-detail-item label{font-size:12px}.receipt-detail-item .value{font-size:16px;word-break:break-word}.receipt-detail-item.amount .value{font-size:24px}.receipt-detail-header{flex-direction:column;gap:.5rem;text-align:center}.receipt-detail-header h1{font-size:28px}.receipt-detail-header .receipt-id{font-size:14px}.receipt-actions{flex-direction:column;gap:.5rem;padding:1rem 0}.receipt-actions .btn{font-size:14px;justify-content:center;padding:10px 16px;width:100%}.receipt-document{margin:.5rem 0;padding:1rem}.receipt-title-bar{flex-direction:column;gap:.5rem;padding:1rem}.receipt-title-bar h1{font-size:22px}.receipt-number{font-size:13px}.receipt-status{font-size:12px;padding:4px 10px}.meta{flex-direction:column;gap:.75rem}.meta-item{flex:1 1 100%}.photo-section{margin-top:1rem}.photo-section img{height:auto;max-width:100%}}@media screen and (max-width:600px){.receipt-table{display:block!important;overflow-x:visible!important;width:100%!important}.receipt-table tbody{gap:.5rem!important}.receipt-table tbody,.receipt-table tr{display:flex!important;flex-direction:column!important;width:100%!important}.receipt-table tr{background:#f9fafb!important;background:var(--gray-50,#f9fafb)!important;border:1px solid #e5e7eb!important;border:1px solid var(--gray-200,#e5e7eb)!important;border-radius:8px!important;box-sizing:border-box!important;padding:.75rem!important}.receipt-table th{background:#0000!important;color:#6b7280!important;color:var(--gray-500,#6b7280)!important;display:block!important;font-size:11px!important;padding:0 0 4px!important;text-align:left!important;text-transform:uppercase!important;width:auto!important}.receipt-table td{word-wrap:break-word!important;border:none!important;box-sizing:border-box!important;color:#111827!important;color:var(--gray-900,#111827)!important;display:block!important;font-size:15px!important;font-weight:500!important;overflow-wrap:break-word!important;padding:0 0 8px!important;width:100%!important}.receipt-table td.amount-cell{color:#059669!important;font-size:20px!important;font-weight:700!important}.receipt-table tr:last-child td,.receipt-table tr:last-child th{padding-bottom:0!important}.receipt-detail{max-width:100vw!important}.receipt-detail,.receipt-document{box-sizing:border-box!important;overflow-x:hidden!important;width:100%!important}.receipt-document{max-width:100%!important}.receipt-table{table-layout:fixed!important}}.user-management{margin:0 auto;max-width:1200px;padding:20px}.role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:700;padding:4px 12px;text-transform:uppercase}.role-badge.admin{background:#fef3c7;color:#92400e}.role-badge.user{background:#dbeafe;color:#1e40af}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:700;padding:4px 12px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.btn-sm{font-size:13px;padding:4px 10px}.btn-danger{background:#dc2626;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:4px 10px}.btn-danger:hover{background:#b91c1c}.data-table{background:#fff;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.data-table th{background:#f3f4f6;color:#374151;font-weight:600;padding:12px;text-align:left}.data-table td{border-top:1px solid #e5e7eb;padding:12px}.data-table tr:hover{background:#f9fafb}[data-theme=dark] .data-table{background:#1f2937}[data-theme=dark] .data-table th{background:#374151;color:#e5e7eb}[data-theme=dark] .data-table td{border-color:#4b5563}[data-theme=dark] .data-table tr:hover{background:#374151}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:10px}.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-group span{color:#374151;color:var(--gray-700,#374151);font-size:14px}[data-theme=dark] .checkbox-group span{color:#d1d5db;color:var(--gray-300,#d1d5db)}.modal{margin:20px!important;max-width:calc(100% - 40px)!important;padding:20px 30px!important}.modal-body{padding:15px 0!important}.form-group{padding:8px 5px!important}.modal-actions{margin-top:10px!important;padding:15px 0!important}.modal{max-width:50%!important;width:50%!important}@media (max-width:768px){.modal{max-width:90%!important;width:90%!important}}.header-project-selector{align-items:center;border-right:1px solid #e5e7eb;border-right:1px solid var(--gray-200);display:flex;gap:8px;margin-right:15px;padding-right:15px}.header-project-selector label{color:#6b7280;color:var(--gray-500);font-size:12px;white-space:nowrap}.project-select{background:#fff;background:var(--white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:4px;color:#111827;color:var(--gray-900);cursor:pointer;font-size:13px;padding:4px 8px}.project-select:hover{border-color:#2563eb;border-color:var(--primary)}[data-theme=dark] .header-project-selector,[data-theme=dark] .project-select{border-color:#4b5563;border-color:var(--gray-600)}[data-theme=dark] .project-select{background:#f3f4f6;background:var(--gray-100);color:#111827;color:var(--gray-900)}.photo-container .receipt-photo{height:150px}.btn-delete-photo{align-items:center;background:#ff3b30e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;position:absolute;right:8px;top:8px;width:32px}.btn-delete-photo:hover{background:#ff3b30}.selected-files{background:#f3f4f6;background:var(--gray-100);border-radius:8px;margin-top:12px;padding:12px}.selected-files ul{color:#4b5563;color:var(--gray-600);font-size:13px;margin:8px 0;padding-left:20px}[data-theme=dark] .photos-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}[data-theme=dark] .selected-files{background:#e5e7eb;background:var(--gray-200)}.photos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));justify-items:center;margin-bottom:20px}.photo-container{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:8px;max-width:350px;overflow:hidden;position:relative}.photo-container .receipt-photo{display:block;height:220px;object-fit:cover;width:100%}[data-theme=dark] .photos-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}[data-theme=dark] .photo-container{max-width:300px}[data-theme=dark] .photo-container .receipt-photo{height:200px}.comments-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:20px 0;padding:20px}.comments-section h3{color:#333;margin-bottom:16px}.add-comment{margin-bottom:20px}.add-comment textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;margin-bottom:10px;padding:12px;resize:vertical;width:100%}.add-comment textarea:focus{border-color:#2563eb;outline:none}.comments-list{display:flex;flex-direction:column;gap:12px}.comment{background:#f9f9f9;border-radius:6px;padding:12px}.comment-header{align-items:center;display:flex;gap:10px;margin-bottom:8px}.comment-header strong{color:#333}.comment-date{color:#888;flex:1 1;font-size:12px}.btn-delete-comment{background:none;border:none;cursor:pointer;opacity:.6;padding:4px;transition:opacity .2s}.btn-delete-comment:hover{opacity:1}.comment-content{color:#555;line-height:1.5}.no-comments{color:#888;font-style:italic}.crop-modal{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.crop-container{background:#fff;border-radius:8px;max-height:90vh;max-width:90vw;overflow:auto;padding:20px}.crop-container h3{margin-bottom:16px;text-align:center}.crop-container img{max-height:60vh;max-width:100%}.crop-buttons{display:flex;gap:12px;justify-content:center;margin-top:16px}.crop-quality{margin:16px 0;text-align:center}.crop-quality label{display:block;font-weight:500;margin-bottom:8px}.crop-options{display:flex;flex-direction:column;gap:12px;margin:16px 0}.crop-quality input[type=range]{max-width:300px;width:100%}.crop-grayscale label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:8px}.crop-grayscale input[type=checkbox]{height:18px;width:18px}.crop-rotate{display:flex;gap:8px;justify-content:center;margin-top:8px}.crop-rotate .btn{min-width:100px}
/*# sourceMappingURL=main.87fdf0fc.css.map*/