.donation-container{max-width:900px;margin:2.5rem auto;padding:2rem 2.25rem;border-radius:18px;background:var(--color-white);color:var(--color-neutral-900);box-shadow:0 18px 45px #0f172a1f;border:5px solid var(--color-primary)}.donation-steps-header{display:flex;align-items:center;gap:.35rem;margin-bottom:1.5rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-neutral-500)}.step-badge{width:24px;height:24px;border-radius:999px;border:2px solid var(--color-border-medium);display:flex;align-items:center;justify-content:center;font-size:.7rem;background:var(--color-white)}.step-badge.active{border-color:var(--color-primary);background:var(--color-primary);color:var(--color-white);font-weight:600}.step-badge.done{border-color:var(--color-success);background:var(--color-success);color:var(--color-white)}.step-label{margin-right:.75rem}.step-label.active{color:var(--color-neutral-950);font-weight:600}.step-label.done{color:var(--color-success);font-weight:500}.step-separator{flex:1;height:2px;background:linear-gradient(to right,var(--color-info-border),transparent)}.donation-title{font-size:1.6rem;font-weight:700;margin-bottom:.2rem;color:var(--color-primary-dark)}.donation-subtitle{font-size:.95rem;color:var(--color-neutral-500);margin-bottom:1.7rem}.amount-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.9rem}.amount-card{border-radius:14px;border:1px solid var(--color-neutral-100);background:var(--color-neutral-50);padding:.95rem .8rem;font-size:1rem;text-align:center;cursor:pointer;transition:all .15s ease-out;font-weight:600;color:var(--color-neutral-950)}.amount-card:hover{border-color:var(--color-primary);box-shadow:0 9px 20px #00339926;transform:translateY(-1px)}.amount-card--selected{border-color:var(--color-primary);background:var(--color-info-bg);box-shadow:0 10px 26px #00339938}.amount-card--other{text-align:left;cursor:default}.amount-other-label{font-size:.8rem;color:var(--color-neutral-500);display:block;margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.08em}.amount-other-input-wrapper{display:flex;align-items:center;border-radius:999px;background:var(--color-white);border:1px solid var(--color-neutral-200);padding:.35rem .75rem}.amount-other-input{background:transparent;border:none;outline:none;color:var(--color-neutral-950);font-size:.95rem;flex:1}.amount-other-input::placeholder{color:var(--color-neutral-300)}.amount-other-suffix{font-size:.85rem;color:var(--color-neutral-500);margin-left:.25rem}.amount-preview{margin-top:1rem;font-size:.95rem;color:var(--color-neutral-700)}.amount-error{margin-top:.8rem;font-size:.9rem;color:var(--color-error-text);background:var(--color-error-border);border-radius:10px;padding:.55rem .75rem;border:1px solid var(--color-error-border)}.donation-actions{margin-top:1.6rem;display:flex;justify-content:flex-end}.btn-primary{padding:.65rem 1.7rem;border-radius:999px;border:none;cursor:pointer;background:var(--color-secondary);color:var(--color-primary-dark);font-weight:700;font-size:.95rem;box-shadow:0 10px 24px #f59e0b73;transition:transform .1s ease-out,box-shadow .1s ease-out,background .1s ease-out}.btn-primary:hover{background:var(--color-secondary);transform:translateY(-1px);box-shadow:0 14px 32px #f59e0b99}.donation-summary{margin-bottom:1.1rem;font-size:.98rem;color:var(--color-neutral-700)}.btn-secondary{padding:.55rem 1.3rem;border-radius:999px;border:1px solid var(--color-border-medium);cursor:pointer;background:var(--color-white);color:var(--color-primary-dark);font-weight:500;font-size:.9rem;margin-top:1.5rem;transition:background .1s ease-out,box-shadow .1s ease-out,transform .1s ease-out}.btn-secondary:hover{background:var(--color-neutral-50);box-shadow:0 6px 16px #0f172a1f;transform:translateY(-1px)}.upload-container{max-width:720px;margin:2rem auto;padding:1.5rem;border-radius:.75rem;background:var(--color-white);box-shadow:0 4px 12px #00000014}.upload-title{margin-top:0;margin-bottom:.75rem;font-size:1.5rem;font-weight:700;color:var(--color-primary-dark)}.upload-label{display:block;margin-bottom:.25rem;font-size:.9rem;color:var(--color-neutral-700);font-weight:500}.upload-select{padding:.35rem .5rem;border-radius:6px;border:1px solid var(--color-border-medium);font-size:.95rem;background:var(--color-white);color:var(--color-neutral-950)}.upload-description{margin-bottom:1rem;font-size:.95rem;color:var(--color-neutral-500)}.upload-actions{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.upload-file-label{padding:.45rem .75rem;background:var(--color-neutral-100);border-radius:6px;cursor:pointer;border:1px solid var(--color-border-medium);font-size:.95rem;font-weight:500;color:var(--color-neutral-900);transition:all .15s ease-out}.upload-file-label:hover{background:var(--color-border-medium);border-color:var(--color-neutral-300)}.upload-camera-btn{padding:.45rem .75rem;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;border:1px solid;transition:all .15s ease-out}.upload-camera-btn--active{background:var(--color-error);color:var(--color-white);border-color:var(--color-error)}.upload-camera-btn--inactive{background:var(--color-neutral-100);color:var(--color-neutral-900);border-color:var(--color-border-medium)}.upload-camera-btn--active:hover{background:var(--color-error)}.upload-camera-btn--inactive:hover{background:var(--color-border-medium)}.upload-file-name{font-size:.9rem;color:var(--color-neutral-600);flex:1;min-width:150px}.camera-preview{margin-top:1rem;text-align:center}.camera-video-wrapper{position:relative;display:inline-block}.camera-video{width:100%;max-width:500px;border-radius:.5rem;display:block}.camera-overlay{position:absolute;top:0;left:0;width:100%;max-width:500px;pointer-events:none}.camera-processing-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#10b981e6;color:var(--color-white);padding:1rem 1.5rem;border-radius:1rem;font-size:1.1rem;font-weight:600;box-shadow:0 4px 20px #10b98180;z-index:10}.camera-scan-message{position:absolute;bottom:10px;left:50%;transform:translate(-50%);color:var(--color-white);padding:.5rem 1rem;border-radius:.5rem;font-size:.9rem;font-weight:500;white-space:nowrap;z-index:10}.camera-scan-message--good{background:#10b981e6}.camera-scan-message--medium{background:#fbbf24e6}.camera-scan-message--poor{background:#ef4444e6}.camera-controls{margin-top:.75rem;display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.camera-btn{padding:.6rem 1.5rem;color:var(--color-white);border-radius:6px;cursor:pointer;border:none;font-size:1rem;font-weight:500;transition:all .15s ease-out}.camera-btn:disabled{cursor:not-allowed;opacity:.6}.camera-btn--detect-active{background:var(--color-error)}.camera-btn--detect-active:hover:not(:disabled){background:var(--color-error)}.camera-btn--detect-inactive{background:var(--color-primary-light)}.camera-btn--detect-inactive:hover:not(:disabled){background:var(--color-primary)}.camera-btn--capture-good{background:var(--color-success)}.camera-btn--capture-good:hover:not(:disabled){background:var(--color-success)}.camera-btn--capture-medium{background:var(--color-warning)}.camera-btn--capture-medium:hover:not(:disabled){background:var(--color-warning)}.camera-btn--capture-poor{background:var(--color-neutral-300)}.camera-help-text{font-size:.85rem;color:var(--color-neutral-500);margin-top:.75rem}.upload-process-btn{padding:.6rem 1.5rem;background:var(--color-success);color:var(--color-white);border-radius:6px;cursor:pointer;border:none;font-size:1rem;font-weight:500;width:100%;margin-top:1rem;transition:all .15s ease-out}.upload-process-btn:disabled{background:var(--color-neutral-300);cursor:not-allowed}.upload-process-btn:hover:not(:disabled){background:var(--color-success);box-shadow:0 4px 12px #10b9814d}.upload-progress{margin-top:1rem}.upload-progress-bar{width:100%;height:8px;background:var(--color-neutral-100);border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--color-primary-light);transition:width .3s ease}.upload-progress-text{font-size:.85rem;color:var(--color-neutral-500);margin-top:.5rem}.upload-status{margin-top:.75rem;white-space:pre-line}.upload-status--ok{color:var(--color-success)}.upload-status--error{color:var(--color-error)}.extracted-fields{margin-top:1.25rem;padding:1rem;border-radius:.5rem;background:var(--color-neutral-50);border:1px solid var(--color-neutral-100)}.extracted-fields-title{margin-top:0;margin-bottom:.75rem;font-size:1.2rem;font-weight:600;color:var(--color-primary-dark)}.extracted-fields-note{font-size:.85rem;margin-top:0;margin-bottom:.75rem;color:var(--color-neutral-500)}.extracted-fields-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.75rem 1.5rem;font-size:.95rem}.mrz-success-badge{margin-top:1rem;padding:.75rem;background:var(--color-success-border);border:1px solid var(--color-success-border);border-radius:.5rem;font-size:.9rem;color:var(--color-success-text)}.debug-section{margin-top:1rem}.debug-summary{cursor:pointer;font-size:.9rem;color:var(--color-neutral-500);font-weight:500}.debug-content{margin-top:.5rem;padding:.75rem;background:var(--color-border-light);border-radius:.5rem;max-height:220px;overflow:auto;font-size:.75rem;white-space:pre-wrap;font-family:monospace}.debug-note{font-size:.85rem;color:var(--color-neutral-500);margin-top:.5rem;margin-bottom:0}.contract-container{max-width:960px;margin:2rem auto;padding:1.5rem;border-radius:.75rem;background:var(--color-white);box-shadow:0 4px 12px #00000014}.contract-title{margin-top:0;margin-bottom:.75rem;font-size:1.5rem;font-weight:700;color:var(--color-primary-dark)}.contract-text{border:1px solid var(--color-neutral-100);border-radius:.5rem;padding:1rem;max-height:320px;overflow:auto;background:var(--color-neutral-50);font-size:.9rem;white-space:pre-wrap;line-height:1.6;color:var(--color-neutral-700)}.contract-signature-section{margin-top:1.5rem;text-align:center}.contract-signature-wrapper{border-radius:.75rem;border:1px solid var(--color-neutral-100);background:var(--color-neutral-50);margin:0 auto 1rem;width:100%;max-width:640px;height:220px;position:relative}.contract-signature-canvas{width:100%;height:100%;border-radius:.75rem;cursor:crosshair}.contract-clear-btn{padding:.6rem 2.5rem;border-radius:999px;border:2px solid var(--color-info);background:var(--color-white);color:var(--color-info);font-weight:600;cursor:pointer;font-size:1rem;transition:all .15s ease-out}.contract-clear-btn:hover{background:var(--color-info-light);border-color:var(--color-info)}.contract-details-section{margin-top:2rem;display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1.3fr);gap:1.5rem;align-items:flex-start}.contract-terms-text{font-size:.85rem;color:var(--color-neutral-500);margin:0;line-height:1.5}.contract-terms-text a{color:var(--color-primary);text-decoration:none;font-weight:500}.contract-terms-text a:hover{text-decoration:underline}.contract-fields-wrapper{display:flex;flex-direction:column;gap:.75rem}.contract-error{margin-top:.75rem;color:var(--color-error);font-size:.9rem}.contract-actions{margin-top:1.75rem;display:flex;justify-content:space-between;gap:1rem}.hidden{display:none}.select-wrapper{margin-bottom:.75rem}.upload-button-wrapper{margin-top:1rem}
