.product-card{background:#fff;border-radius:2rem;border:1px solid var(--border);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s ease;box-shadow:0 4px 6px -1px #0000000d}.product-header-img{height:200px;display:flex;align-items:center;justify-content:center;font-size:4rem}.product-body{padding:2.5rem;flex:1;display:flex;flex-direction:column}body{background-color:var(--primary)!important;color:#fff!important}.product-category{font-size:1.15rem;font-weight:400;margin-bottom:.5rem;color:#fff}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;transition:grid-template-columns .5s cubic-bezier(.2,.8,.2,1)}#productsLayout.with-form .product-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}#productsLayout{max-width:900px;margin:0 auto;display:flex;gap:0;align-items:flex-start;transition:max-width .5s cubic-bezier(.2,.8,.2,1),gap .5s cubic-bezier(.2,.8,.2,1)}#productsLayout.with-form{max-width:1100px;gap:2.5rem}#productsTitle{text-align:center;margin-bottom:2rem;font-weight:700;font-size:1.85rem;color:#fff}#productsLeft{flex:1;min-width:0}#productsRight{width:0;opacity:0;visibility:hidden;overflow:hidden;transition:width .5s cubic-bezier(.2,.8,.2,1),opacity .2s ease,visibility .2s ease;padding-top:6.5rem}#productsLayout.with-form #productsRight{width:calc(50% - 2rem);opacity:1;visibility:visible;transition:width .5s cubic-bezier(.2,.8,.2,1),opacity .4s ease .3s,visibility 0s .3s}#productsTitle{text-align:center;margin-bottom:3.5rem;font-weight:700;font-size:2.25rem;color:#fff}#productsLayout.with-form #productsTitle{text-align:left}.product-btn{background-color:#e2e8f0;border-radius:10px;padding:1rem 1.25rem;display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--primary)}.product-btn .icon{font-size:2.5rem;line-height:1;display:flex;align-items:center;justify-content:center}.product-btn .title{font-size:1rem;font-weight:700;margin:0;line-height:1.2}.quote-form-card{background:#e2e8f0;width:100%;min-width:380px;padding:2rem 1.75rem 1.75rem;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;flex-direction:column;align-items:center;position:sticky;top:100px}.quote-form-group{width:100%;display:flex;flex-direction:column;gap:.15rem;margin-bottom:.6rem}.quote-form-group label{color:#203967;font-weight:700;font-size:.95rem}.quote-select{width:100%;padding:.5rem .85rem;border:1px solid #203967;border-radius:.75rem;font-size:.95rem;font-weight:600;color:#203967;background-color:transparent;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fba85c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 1rem center;background-size:1.2em;outline:none}.provider-card{background:#fffdf5;border:2px solid #e2c87a;border-radius:.85rem;padding:1rem 1.15rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative}.provider-card.recommended{border-color:#fba85c;box-shadow:0 4px 12px #fba85c33}.provider-card-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem;justify-content:center}.provider-logo{width:32px;height:32px;object-fit:contain;flex-shrink:0}.provider-logo-text{flex-shrink:0;display:flex;align-items:center;justify-content:center;min-width:28px;min-height:22px}.provider-name{font-size:.85rem;font-weight:700;color:#203967;line-height:1.2;text-decoration:underline}.provider-premium{text-align:center;margin-bottom:.4rem}.premium-label{display:block;font-size:.65rem;color:#64748b;font-style:italic}.premium-amount{font-size:1.35rem;font-weight:800;color:#203967}.provider-score{text-align:center;margin-bottom:.5rem}.score-label{font-size:.7rem;font-weight:700;color:#203967}.score-value{display:block;font-size:.85rem;font-weight:700;color:#203967}.provider-details{list-style:disc;padding-left:1.25rem;margin:0 0 .5rem;font-size:.7rem;color:#334155;line-height:1.5}.provider-details li{margin-bottom:.1rem}.provider-badges{display:flex;flex-direction:column;gap:.15rem;margin-bottom:.5rem}.badge-recommended,.badge-system{font-size:.65rem;color:#203967;font-weight:600}.provider-select-btn{display:block;width:100%;background:#ffc94d;color:#203967;border:2px solid #203967;border-radius:.5rem;padding:.4rem 1rem;font-weight:800;font-size:.8rem;cursor:pointer;text-align:center;letter-spacing:.03em;transition:background .2s ease}.invoice-modal-overlay{position:fixed;inset:0;background:#0000008c;z-index:9999;display:flex;align-items:center;justify-content:center;padding:2rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.invoice-modal{background:#fff;border-radius:1.5rem;max-width:560px;width:100%;padding:2rem 2.5rem 2.5rem;position:relative;box-shadow:0 25px 50px #0003;animation:slideUp .35s cubic-bezier(.2,.8,.2,1);max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.invoice-modal-close{position:absolute;top:1rem;right:1.25rem;background:none;border:none;font-size:2rem;color:#94a3b8;cursor:pointer;line-height:1;transition:color .2s}.invoice-steps{display:flex;align-items:flex-start;justify-content:center;gap:0;margin-bottom:2rem;padding:0 1rem}.invoice-steps .step{display:flex;flex-direction:column;align-items:center;gap:.4rem;min-width:70px}.step-circle{width:36px;height:36px;border-radius:50%;background:#c8d6e8;color:#fff;font-weight:800;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:background .3s}.invoice-steps .step.active .step-circle{background:#fba85c}.step-label{font-size:.65rem;font-weight:600;color:#64748b;text-align:center;line-height:1.25}.invoice-steps .step.active .step-label{color:#203967;font-weight:700}.step-line{flex:1;height:3px;background:#e2e8f0;margin-top:17px;min-width:20px}.invoice-content{border:2px solid #fba85c;border-radius:1rem;overflow:hidden}.invoice-provider-header{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;background:#f8fafc;border-bottom:1px solid #e2e8f0}.invoice-provider-logo{font-size:2.5rem;line-height:1;flex-shrink:0}.invoice-provider-name{font-size:1.1rem;font-weight:800;color:#203967;margin:0;line-height:1.3}.invoice-details{padding:1.25rem 1.5rem;border-bottom:2px dashed #fba85c}.invoice-details p{margin:.25rem 0;font-size:.88rem;color:#334155}.invoice-breakdown{list-style:disc;padding-left:1.5rem;margin:0;font-size:.88rem;color:#334155;line-height:1.7}.invoice-total{padding:1rem 1.5rem;text-align:center;background:#fffdf5}.invoice-total-label{display:block;font-size:.85rem;font-weight:700;color:#203967;margin-bottom:.25rem}.invoice-total-amount{font-size:2rem;font-weight:900;color:#16a34a}.invoice-actions{display:flex;gap:1.25rem;justify-content:center;padding:1.5rem}.invoice-btn-qr{background:#16a34a;color:#fff;border:none;border-radius:.65rem;padding:.7rem 2rem;font-weight:800;font-size:1rem;cursor:pointer;transition:background .2s}.invoice-btn-upload{background:#203967;color:#fff;border:none;border-radius:.65rem;padding:.7rem 2rem;font-weight:800;font-size:1rem;cursor:pointer;transition:background .2s}.invoice-steps .step.completed .step-circle{background:#16a34a}.invoice-steps .step.completed .step-circle:after{content:"✓";font-size:.85rem}.invoice-steps .step.completed .step-label{color:#16a34a;font-weight:700}.step-line.completed{background:#16a34a}.payment-method-option{display:flex;align-items:center;gap:.75rem;padding:1rem;border:2px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:border-color .2s}.payment-method-option:has(input:checked){border-color:#203967;background:#f0f5ff}
