.paint-visualizer-section{padding:72px 0;background:#fff;min-height:60vh}.paint-visualizer-section .section-header{text-align:center;margin-bottom:32px}.paint-visualizer-section .section-header h2{font-size:var(--font-size-3xl);color:var(--color-heading);margin-bottom:var(--spacing-sm)}.paint-visualizer-section .section-header p{color:#555;max-width:600px;margin:0 auto;font-size:var(--font-size-lg)}.pv-mode-toggle{display:flex;justify-content:center;gap:0;margin-bottom:24px;background:var(--color-white);border-radius:50px;box-shadow:var(--shadow-lg);padding:4px;max-width:320px;margin-left:auto;margin-right:auto}.pv-mode-tab{flex:1;padding:10px 24px;border:none;border-radius:50px;background:transparent;cursor:pointer;font-family:inherit;font-size:15px;font-weight:600;color:#888;transition:all .2s ease;text-align:center}.pv-mode-tab:hover{color:var(--color-heading)}.pv-mode-tab.active{background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #e91e634d}.pv-cladding-select{padding:4px 8px;border:1px solid #d0d0d0;border-radius:var(--border-radius-sm);font-family:inherit;font-size:12px;color:var(--color-heading);background:var(--color-bg-light);cursor:pointer;outline:none;transition:border-color .2s}.pv-cladding-select:focus{border-color:var(--color-primary)}.pv-container{max-width:900px;margin:0 auto}.pv-upload{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:32px;margin-bottom:24px}.pv-dropzone{border:2px dashed #d0d0d0;border-radius:var(--border-radius-md);padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--color-bg-light)}.pv-dropzone:hover,.pv-dropzone.dragging{border-color:var(--color-primary);background:#e91e6308}.pv-dropzone-icon{font-size:48px;margin-bottom:12px;display:block}.pv-dropzone-text{font-size:var(--font-size-lg);color:var(--color-heading);font-weight:500;margin-bottom:4px}.pv-dropzone-hint{font-size:var(--font-size-sm);color:#888}.pv-preview-wrap{position:relative;border-radius:var(--border-radius-md);overflow:hidden}.pv-preview-img{width:100%;max-height:400px;object-fit:contain;display:block;background:#f0f0f0;border-radius:var(--border-radius-md)}.pv-preview-remove{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#0009;color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .2s}.pv-preview-remove:hover{background:#e91e63e6}.pv-colours{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:32px;margin-bottom:24px}.pv-colours-title{font-size:var(--font-size-xl);color:var(--color-heading);margin-bottom:20px;text-align:center}.pv-brand-tabs{display:flex;gap:8px;margin-bottom:20px;justify-content:center}.pv-brand-tab{padding:8px 20px;border:2px solid #e0e0e0;border-radius:50px;background:var(--color-white);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;color:var(--color-heading);transition:all .2s ease}.pv-brand-tab:hover{border-color:var(--color-primary)}.pv-brand-tab.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.pv-colour-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-bottom:20px}.pv-colour-swatch{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;border:2px solid transparent;border-radius:var(--border-radius-md);cursor:pointer;transition:all .2s ease;background:none;font-family:inherit}.pv-colour-swatch:hover{border-color:var(--color-primary);transform:translateY(-2px)}.pv-colour-swatch.selected{border-color:var(--color-primary);box-shadow:0 0 0 3px #e91e6326}.pv-swatch-circle{width:44px;height:44px;border-radius:50%;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.pv-swatch-name{font-size:11px;color:#555;text-align:center;line-height:1.2}.pv-custom-colour{display:flex;align-items:center;gap:12px;padding:16px;background:var(--color-bg-light);border-radius:var(--border-radius-md);margin-bottom:20px}.pv-custom-colour label{font-weight:500;font-size:14px;color:var(--color-heading);white-space:nowrap}.pv-colour-input-wrap{display:flex;align-items:center;gap:8px}.pv-colour-native-input{width:40px;height:40px;border:none;border-radius:var(--border-radius-sm);cursor:pointer;padding:0;background:none}.pv-colour-native-input::-webkit-color-swatch-wrapper{padding:0}.pv-colour-native-input::-webkit-color-swatch{border:2px solid rgba(0,0,0,.1);border-radius:var(--border-radius-sm)}.pv-colour-hex-input{width:100px;padding:8px 12px;border:2px solid #e0e0e0;border-radius:var(--border-radius-md);font-family:inherit;font-size:14px;text-transform:uppercase}.pv-colour-hex-input:focus{outline:none;border-color:var(--color-primary)}.pv-add-colour-btn{padding:8px 16px;border:2px solid var(--color-primary);border-radius:50px;background:var(--color-white);color:var(--color-primary);cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;transition:all .2s ease}.pv-add-colour-btn:hover{background:var(--color-primary);color:#fff}.pv-area-slots{margin-bottom:20px}.pv-area-slots-hint{font-size:14px;color:#888;text-align:center;margin-bottom:12px}.pv-area-slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.pv-area-slot{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border:2px solid #e0e0e0;border-radius:var(--border-radius-md);background:var(--color-white);cursor:pointer;transition:all .2s ease;font-family:inherit;position:relative}.pv-area-slot:hover{border-color:var(--color-primary)}.pv-area-slot.active{border-color:var(--color-primary);box-shadow:0 0 0 3px #e91e6326;background:#e91e6305}.pv-area-slot.filled{border-color:#ccc}.pv-area-slot.filled.active{border-color:var(--color-primary)}.pv-area-slot-label{font-size:13px;font-weight:600;color:var(--color-heading);text-transform:uppercase;letter-spacing:.5px}.pv-area-slot-swatch-wrap{display:flex;align-items:center;gap:8px}.pv-area-slot-swatch{width:28px;height:28px;border-radius:50%;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.pv-area-slot-colour-name{font-size:12px;color:#555;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pv-area-slot-empty{font-size:13px;color:#bbb;font-style:italic}.pv-area-slot-clear{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#00000014;border:none;cursor:pointer;font-size:14px;color:#888;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.pv-area-slot-clear:hover{background:#e91e6326;color:var(--color-primary)}.pv-palette-section{margin-top:20px;padding-top:20px;border-top:1px solid #e8e8e8}.pv-palette-section-label{font-size:14px;color:#555;margin-bottom:12px;text-align:center}.pv-palette-section-label strong{color:var(--color-primary)}.pv-generate-wrap{text-align:center;margin-bottom:24px}.pv-generate-btn{min-width:260px}.pv-generate-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.pv-loading{text-align:center;padding:48px 24px;background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);margin-bottom:24px}.pv-loading-spinner{width:48px;height:48px;border:4px solid #e0e0e0;border-top-color:var(--color-primary);border-radius:50%;animation:pv-spin 1s linear infinite;margin:0 auto 16px}@keyframes pv-spin{to{transform:rotate(360deg)}}.pv-loading-text{font-size:var(--font-size-lg);color:var(--color-heading);font-weight:500;margin-bottom:4px}.pv-loading-subtext{font-size:var(--font-size-sm);color:#888}.pv-result{background:var(--color-white);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:32px;margin-bottom:24px;text-align:center}.pv-result-title{font-size:var(--font-size-xl);color:var(--color-heading);margin-bottom:20px;text-align:center}.pv-comparison{position:relative;overflow:hidden;border-radius:var(--border-radius-md);cursor:ew-resize;user-select:none;-webkit-user-select:none;touch-action:none;display:inline-block;max-width:100%}.pv-comparison>img{display:block;max-width:100%;max-height:80vh;height:auto}.pv-comparison-after{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.pv-comparison-after img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.pv-comparison-slider{position:absolute;top:0;bottom:0;width:4px;background:#fff;cursor:ew-resize;z-index:2;box-shadow:0 0 8px #0000004d}.pv-comparison-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center}.pv-comparison-handle svg{width:20px;height:20px;color:var(--color-heading)}.pv-comparison-label{position:absolute;top:12px;padding:4px 12px;border-radius:50px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#0009;color:#fff;z-index:1}.pv-comparison-label-before{left:12px}.pv-comparison-label-after{right:12px}.pv-placeholder-msg{text-align:center;padding:24px;background:#e91e630d;border:1px dashed rgba(233,30,99,.3);border-radius:var(--border-radius-md);margin-top:16px}.pv-placeholder-msg p{color:var(--color-primary);font-weight:500;margin:0}.pv-placeholder-msg small{color:#888;font-size:13px}.pv-disclaimer{text-align:center;font-size:12px;color:#888;margin-top:12px;font-style:italic}.pv-actions{display:flex;justify-content:center;gap:12px;margin-top:20px;flex-wrap:wrap}.pv-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:20px}.pv-modal{background:var(--color-white);border-radius:var(--border-radius-lg);max-width:480px;width:100%;padding:32px;position:relative}.pv-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:none;border:none;cursor:pointer;font-size:20px;color:#888;display:flex;align-items:center;justify-content:center;transition:color .2s}.pv-modal-close:hover{color:var(--color-primary)}.pv-modal h3{text-align:center;margin-bottom:8px;font-size:var(--font-size-xl);color:var(--color-heading)}.pv-modal-subtitle{text-align:center;color:#555;margin-bottom:24px;font-size:15px}.pv-modal-form{display:flex;flex-direction:column;gap:16px}.pv-modal-field label{display:block;font-weight:500;margin-bottom:6px;font-size:14px;color:var(--color-heading)}.pv-modal-form .calc-input{width:100%}.pv-modal-success{text-align:center;padding:24px 0}.pv-modal-success h3{color:var(--color-primary);margin-bottom:12px}.pv-modal-success p{color:#555;margin-bottom:24px}@media(max-width:768px){.pv-upload,.pv-colours,.pv-result{padding:20px}.pv-area-slots-grid{grid-template-columns:repeat(2,1fr);gap:8px}.pv-mode-toggle{max-width:280px}.pv-colour-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.pv-custom-colour{flex-direction:column;align-items:flex-start}.pv-comparison-label{font-size:10px;padding:3px 8px}.pv-actions{flex-direction:column;align-items:stretch}.pv-actions .btn-cta,.pv-actions .btn-cta-secondary{width:100%;text-align:center;justify-content:center}.paint-visualizer-section .section-header h2{font-size:var(--font-size-2xl)}}@media(max-width:480px){.pv-brand-tabs{flex-direction:column;align-items:stretch}.pv-brand-tab{text-align:center}}.pv-colours-applied{margin-top:16px;padding:16px 20px;background:var(--color-bg-light, #f8f7f5);border-radius:8px;border:1px solid var(--color-border, #e5e2db)}.pv-colours-applied-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted, #6b7280);margin:0 0 10px}.pv-colours-applied-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.pv-colours-applied-item{display:flex;align-items:center;gap:10px;font-size:.95rem;line-height:1.4}.pv-colours-applied-label{font-weight:600;min-width:48px;color:var(--color-text, #1a1a1a)}.pv-colours-applied-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.12);box-shadow:0 1px 2px #00000014}.pv-colours-applied-name{color:var(--color-text, #1a1a1a)}.pv-colours-applied-hex{color:var(--color-text-muted, #6b7280);font-size:.85rem}.pv-search-wrap{position:relative;margin-bottom:1rem}.pv-search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:2px solid #d1d5db;border-radius:9999px;font-size:.95rem;background:#fff;box-shadow:inset 0 1px 3px #0000000f}.pv-search-input::placeholder{color:#9ca3af}.pv-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.1)}.pv-search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1rem;padding:.25rem}.pv-search-clear:hover{color:var(--color-text)}.pv-category-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.pv-category-pill{padding:.4rem .8rem;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);font-size:.85rem;cursor:pointer;transition:all .2s}.pv-category-pill:hover{border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.05)}.pv-category-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.pv-results-count{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.75rem}.pv-load-more-wrap{text-align:center;margin-top:1rem}.pv-load-more-btn{padding:.6rem 1.5rem;background:transparent;border:2px solid var(--color-accent, #b8436d);border-radius:999px;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--color-accent, #b8436d);transition:all .2s}.pv-load-more-btn:hover{background:var(--color-accent, #b8436d);color:#fff}.pv-gen-mode-toggle{display:flex;justify-content:center;gap:0;margin-bottom:.75rem;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);width:fit-content;margin-left:auto;margin-right:auto}.pv-gen-mode-btn{padding:.5rem 1rem;border:none;background:var(--color-surface);cursor:pointer;font-size:.85rem;transition:all .2s}.pv-gen-mode-btn:first-child{border-right:1px solid var(--color-border)}.pv-gen-mode-btn:hover{background:rgba(var(--color-primary-rgb),.05)}.pv-gen-mode-btn.active{background:var(--color-primary);color:#fff}.pv-gen-mode-hint{text-align:center;font-size:.8rem;color:var(--color-text-muted);margin-bottom:1rem}.pv-painted-summary{background:rgba(var(--color-success-rgb, 34, 197, 94),.1);border:1px solid rgba(var(--color-success-rgb, 34, 197, 94),.3);border-radius:var(--radius-md);padding:.75rem 1rem;margin-bottom:1rem;text-align:center}.pv-painted-summary p{margin:0;font-size:.9rem;color:var(--color-text)}.pv-inline-form{margin-top:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius-lg);border:2px solid var(--color-primary)}.pv-inline-form-header{text-align:center;margin-bottom:1.5rem}.pv-inline-form-header h3{font-size:1.25rem;color:var(--color-primary);margin:0 0 .5rem}.pv-inline-form-header p{color:var(--color-text-muted);margin:0;font-size:.9rem}.pv-inline-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem}.pv-form-field-full{grid-column:1 / -1}@media(max-width:600px){.pv-inline-form-grid{grid-template-columns:1fr}}.pv-form-field label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.25rem;color:var(--color-text)}.pv-form-field input{width:100%;padding:.75rem;border:2px solid #d1d5db;border-radius:var(--radius-md);font-size:.95rem}.pv-form-field input:focus{outline:none;border-color:var(--color-primary)}.pv-inline-submit{width:100%;padding:1rem;font-size:1.1rem}.pv-form-privacy{text-align:center;font-size:.8rem;color:var(--color-text-muted);margin:1rem 0 0}.pv-form-error{background:#fef2f2;color:#dc2626;padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.9rem}.pv-form-success{text-align:center;padding:2rem}.pv-success-icon{width:64px;height:64px;color:#22c55e;margin-bottom:1rem}.pv-form-success h3{color:#22c55e;margin:0 0 .5rem}.pv-form-success p{color:var(--color-text-muted);margin:0}.pv-form-field select{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:2px solid #d1d5db;border-radius:var(--radius-md);font-size:.95rem;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b7280' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.pv-form-field select:focus{outline:none;border-color:var(--color-primary)}.pv-form-field textarea{width:100%;padding:.75rem;border:2px solid #d1d5db;border-radius:var(--radius-md);font-size:.95rem;resize:vertical;min-height:100px;font-family:inherit}.pv-form-field textarea:focus{outline:none;border-color:var(--color-primary)}.pv-area-limit-warning{background:#fef3c7;color:#92400e;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.85rem;text-align:center;margin-bottom:1rem}.pv-area-slot.disabled{opacity:.5;cursor:not-allowed}.pv-popup-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.pv-popup{background:#fff;border-radius:var(--radius-lg);padding:2rem;max-width:420px;width:100%;text-align:center;box-shadow:0 20px 40px #0003}.pv-popup h3{font-size:1.5rem;color:var(--color-primary);margin:0 0 1rem}.pv-popup p{color:var(--color-text);margin:0 0 1rem;line-height:1.6}.pv-popup-actions{display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0 1rem}.pv-popup-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;text-decoration:none;cursor:pointer;border:none;transition:all .2s ease}.pv-popup-btn.primary{background:var(--color-primary);color:#fff}.pv-popup-btn.primary:hover{background:var(--color-primary-dark)}.pv-popup-btn.secondary{background:#f1f5f9;color:var(--color-text)}.pv-popup-btn.secondary:hover{background:#e2e8f0}.pv-popup-note{font-size:.85rem;color:var(--color-text-muted);margin:0}.pv-popup.blocked h3{color:#dc2626}
