.checkout-overlay{position:fixed;inset:0;background:#0f172aa6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding:16px;overflow-y:auto}.checkout-modal{background:#fff;border-radius:20px;width:100%;max-width:640px;margin:auto;box-shadow:0 24px 80px #0003;display:flex;flex-direction:column;overflow:hidden}.checkout-header{background:linear-gradient(135deg,#1e3a8a,#2563eb);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.checkout-header-title{color:#fff;font-size:.9375rem;font-weight:700;letter-spacing:-.01em}.checkout-close-btn{color:#ffffffb3;background:#ffffff1a;border:none;border-radius:8px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s}.checkout-close-btn:hover{background:#fff3;color:#fff}.checkout-steps{display:flex;align-items:center;justify-content:center;padding:20px 24px 0;gap:0}.checkout-step{display:flex;flex-direction:column;align-items:center;gap:6px}.checkout-step-circle{width:32px;height:32px;border-radius:50%;background:#e2e8f0;color:#94a3b8;font-size:.8125rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s}.checkout-step.active .checkout-step-circle{background:#2563eb;color:#fff;box-shadow:0 0 0 4px #2563eb26}.checkout-step.done .checkout-step-circle{background:#16a34a;color:#fff}.checkout-step-label{font-size:.6875rem;font-weight:600;color:#94a3b8;white-space:nowrap}.checkout-step.active .checkout-step-label{color:#2563eb}.checkout-step.done .checkout-step-label{color:#16a34a}.checkout-step-line{flex:1;height:2px;background:#e2e8f0;margin:-14px 8px 0;min-width:40px;transition:background .2s}.checkout-step-line.done{background:#16a34a}.checkout-product-bar{margin:16px 24px 0;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.checkout-product-img-wrap{width:48px;height:48px;background:#f1f5f9;border-radius:8px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}.checkout-product-img-wrap img{width:100%;height:100%;object-fit:contain}.checkout-product-name{font-size:.875rem;font-weight:700;color:#0f172a}.checkout-product-series{font-size:.75rem;color:#64748b}.checkout-product-price-value{font-size:.9375rem;font-weight:800;color:#2563eb;text-align:right}.checkout-product-discount{font-size:.7rem;color:#16a34a;font-weight:600;text-align:right}.checkout-body{padding:20px 24px;overflow-y:auto;max-height:60vh}.checkout-mode-toggle{display:flex;background:#f1f5f9;border-radius:10px;padding:3px;margin-bottom:20px}.checkout-mode-btn{flex:1;padding:8px 0;border:none;background:transparent;border-radius:8px;font-size:.8125rem;font-weight:600;color:#64748b;cursor:pointer;transition:all .15s}.checkout-mode-btn.active{background:#fff;color:#2563eb;box-shadow:0 1px 4px #00000014}.tipo-pessoa-toggle{display:flex;gap:10px}.tipo-btn{flex:1;padding:10px 12px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;font-size:.8125rem;font-weight:600;color:#475569;cursor:pointer;display:flex;align-items:center;gap:6px;justify-content:center;transition:all .15s}.tipo-btn:hover{border-color:#93c5fd;color:#2563eb}.tipo-btn.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.form-section{margin-bottom:16px}.form-section-title{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#475569;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.form-row{margin-bottom:12px}.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group{display:flex;flex-direction:column}.form-label{font-size:.75rem;font-weight:600;color:#475569;margin-bottom:5px}.form-input{padding:9px 12px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#0f172a;background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;width:100%}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-input.error{border-color:#ef4444}.form-error{font-size:.72rem;color:#ef4444;margin-top:4px;font-weight:500}.input-with-action{display:flex;gap:6px}.input-with-action .form-input{flex:1}.input-action-btn{padding:9px 12px;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:8px;color:#2563eb;font-size:.75rem;font-weight:700;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:4px;transition:background .15s}.input-action-btn:hover{background:#dbeafe}.checkout-info-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 14px;margin-bottom:16px}.checkout-error-box{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px 14px;font-size:.8125rem;color:#dc2626;display:flex;align-items:flex-start;gap:8px}.frete-loading{display:flex;align-items:center;gap:12px;padding:24px;justify-content:center;color:#2563eb;font-size:.875rem;font-weight:500}.frete-opcoes{display:flex;flex-direction:column;gap:8px}.frete-opcao{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1.5px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;text-align:left;transition:all .15s;width:100%}.frete-opcao:hover{border-color:#93c5fd;background:#f8fafc}.frete-opcao.selected{border-color:#2563eb;background:#eff6ff}.frete-opcao-logo{width:40px;height:40px;border-radius:8px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.frete-opcao-logo img{width:32px;height:32px;object-fit:contain}.frete-opcao-info{flex:1}.frete-opcao-name{font-size:.875rem;font-weight:700;color:#0f172a}.frete-opcao-company{font-size:.75rem;color:#64748b}.frete-opcao-prazo{font-size:.72rem;color:#475569;display:flex;align-items:center;gap:3px;margin-top:2px}.frete-opcao-price{font-size:.9375rem;font-weight:800;color:#0f172a;white-space:nowrap}.frete-opcao-radio{width:18px;height:18px;border-radius:50%;border:2px solid #cbd5e1;flex-shrink:0;transition:all .15s;position:relative}.frete-opcao-radio.checked{border-color:#2563eb;background:#2563eb}.frete-opcao-radio.checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#fff}.checkout-order-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;margin-bottom:16px}.order-summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;font-size:.8125rem;color:#475569;border-bottom:1px solid #f1f5f9}.order-summary-row:last-child{border-bottom:none}.order-summary-row.discount{color:#16a34a}.order-summary-row.total{font-size:.9375rem;font-weight:800;color:#0f172a;background:#fff}.order-summary-row.total span:last-child{color:#2563eb}.pagamento-metodos{margin-bottom:16px}.pagamento-metodos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.metodo-btn{padding:12px 10px;border:1.5px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:all .15s}.metodo-btn:hover{border-color:#93c5fd;background:#f8fafc}.metodo-btn.selected{border-color:#2563eb;background:#eff6ff}.metodo-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.metodo-icon.pix{background:#dcfce7;color:#16a34a}.metodo-icon.boleto{background:#fef9c3;color:#a16207}.metodo-icon.cartao{background:#eff6ff;color:#2563eb}.metodo-name{font-size:.8125rem;font-weight:700;color:#0f172a}.metodo-desc{font-size:.69rem;color:#64748b}.pagamento-pix-info{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:10px;padding:14px;margin-bottom:12px}.checkout-confirmacao{display:flex;flex-direction:column;align-items:center;padding:8px 0 16px}.confirmacao-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.confirmacao-icon.success{background:linear-gradient(135deg,#16a34a,#22c55e)}.confirmacao-icon.pending{background:linear-gradient(135deg,#d97706,#f59e0b)}.confirmacao-icon.error{background:linear-gradient(135deg,#dc2626,#ef4444)}.confirmacao-title{font-size:1.25rem;font-weight:800;color:#0f172a;margin-bottom:6px;text-align:center}.confirmacao-subtitle{font-size:.875rem;color:#64748b;margin-bottom:16px;text-align:center}.confirmacao-numero{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:8px 16px;font-size:.8125rem;color:#1e40af;margin-bottom:16px}.pix-qr-box{display:flex;flex-direction:column;align-items:center;width:100%;padding:16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px}.pix-qr-img{width:200px;height:200px;border-radius:8px;background:#fff;padding:8px;border:1px solid #e2e8f0}.pix-code-box{background:#fff;border:1px solid #e2e8f0;border-radius:6px;padding:8px 10px;font-size:.72rem;font-family:monospace;color:#0f172a;word-break:break-all;width:100%}.btn-pix-copiar{margin-top:8px;padding:8px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;font-size:.8125rem;font-weight:700;cursor:pointer;width:100%;transition:background .15s}.btn-pix-copiar:hover{background:#1d4ed8}.boleto-box{width:100%;padding:16px;background:#fffbeb;border:1px solid #fef08a;border-radius:12px;margin-bottom:12px;display:flex;flex-direction:column;align-items:center}.checkout-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid #f1f5f9;background:#fafafa;flex-shrink:0;gap:12px}.btn-checkout-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.btn-checkout-primary:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 14px #2563eb59;transform:translateY(-1px)}.btn-checkout-primary:disabled{opacity:.65;cursor:not-allowed}.btn-checkout-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:transparent;color:#475569;border:1.5px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.btn-checkout-secondary:hover{border-color:#cbd5e1;background:#f8fafc;color:#0f172a}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin .7s linear infinite}@media(max-width:520px){.checkout-overlay{padding:0;align-items:flex-end}.checkout-modal{border-radius:20px 20px 0 0;max-width:100%}.form-row.two-col{grid-template-columns:1fr}.checkout-body{max-height:65vh}}
