*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;line-height:1.15}body{margin:0;min-height:100vh;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit;line-height:1.2}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:none;padding:0}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul,ol{list-style:none}a{text-decoration:none;color:inherit}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;appearance:textfield}#root{isolation:isolate}:root{--primary-color: #0066cc;--primary-dark: #0052a3;--secondary-color: #f0f0f0;--text-color: #1a1a1a;--text-light: #666;--border-color: #ddd;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--bg-dark: #1f2937;--bg-light: #f9fafb;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text-color);background-color:var(--bg-light);background-attachment:fixed;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}html{background-color:var(--bg-light);background-attachment:fixed}.app{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:var(--bg-light);background-attachment:fixed}.app-header{background:linear-gradient(135deg,var(--primary-color) 0%,#0052a3 100%);color:#fff;padding:1.5rem 0;box-shadow:var(--shadow-lg);width:100%}.app-header h1{font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.app-header p{font-size:.95rem;opacity:.95}@media(min-width:768px){.app-header{padding:3rem 0}.app-header h1{font-size:2.5rem}.app-header p{font-size:1.1rem}}.app-main{flex:1;padding:1rem 0;width:100%}@media(min-width:768px){.app-main{padding:2rem 0}}.app-footer{background:var(--bg-dark);color:#fff;text-align:center;padding:2rem 1rem;margin-top:2rem;width:100%}.footer-content{max-width:800px;margin:0 auto;line-height:1.8}.footer-content p{margin:.5rem 0;font-size:.95rem}.container{max-width:100%;margin:0 auto;padding:0 .75rem;width:100%}@media(min-width:768px){.container{padding:0 2rem;max-width:100%}}@media(min-width:1024px){.container{padding:0 3rem}}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%}@media(min-width:768px){.btn{width:auto}}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-light)}.button-group{display:flex;flex-direction:column;gap:1rem;margin-top:2rem;justify-content:center}@media(min-width:768px){.button-group{flex-direction:row}}.survey-container{display:flex;justify-content:center;align-items:center;min-height:500px}.survey-card{background:#fff;border-radius:1rem;padding:1rem;box-shadow:var(--shadow-lg);max-width:600px;width:100%}@media(min-width:768px){.survey-container{min-height:600px}.survey-card{padding:2rem}}.survey-step h2{font-size:1.8rem;margin-bottom:.5rem;color:var(--text-color)}.subtitle{color:var(--text-light);margin-bottom:2rem}.checkbox-grid{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.checkbox-label{display:flex;align-items:flex-start;padding:1rem;border:2px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:all .3s ease}.checkbox-label:hover{border-color:var(--primary-color);background:#f5f9ff}.checkbox-input{width:1.25rem;height:1.25rem;margin-right:1rem;margin-top:.25rem;cursor:pointer;accent-color:var(--primary-color)}.checkbox-content{display:flex;flex-direction:column;gap:.25rem}.checkbox-title{font-weight:600;color:var(--text-color)}.checkbox-desc{font-size:.9rem;color:var(--text-light)}.radio-group{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.radio-label{display:flex;align-items:flex-start;padding:1rem;border:2px solid var(--border-color);border-radius:.5rem;cursor:pointer;transition:all .3s ease}.radio-label:hover{border-color:var(--primary-color);background:#f5f9ff}.radio-input{width:1.25rem;height:1.25rem;margin-right:1rem;margin-top:.25rem;cursor:pointer;accent-color:var(--primary-color)}.radio-content{display:flex;flex-direction:column;gap:.25rem}.radio-title{font-weight:600;color:var(--text-color)}.radio-desc{font-size:.9rem;color:var(--text-light)}.input-group{margin-bottom:2rem}.input-group label{display:block;font-weight:600;margin-bottom:.75rem;color:var(--text-color)}.input-wrapper{display:flex;align-items:center;position:relative}.currency{position:absolute;left:1rem;font-weight:600;color:var(--text-light)}.unit{position:absolute;right:1rem;font-weight:600;color:var(--text-light)}.unit-select{position:absolute;right:.75rem;padding:.5rem 1.75rem .5rem .5rem;border:none;background:transparent;font-weight:600;color:var(--text-light);cursor:pointer;font-size:1rem;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M10.293 3.293L6 7.586 1.707 3.293A1 1 0 00.293 4.707l5 5a1 1 0 001.414 0l5-5a1 1 0 10-1.414-1.414z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center}.unit-select:hover{background-color:#f5f5f5;border-radius:.3rem}.unit-select:focus{outline:none;background-color:#f5f5f5}.input-field{width:100%;padding:.75rem .75rem .75rem 2rem;border:2px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:all .3s ease;background-color:#fff;color:var(--text-color);-webkit-appearance:none;-moz-appearance:none;appearance:none}.input-field::-webkit-input-placeholder{color:var(--text-light)}.input-field::placeholder{color:var(--text-light)}.input-field:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0066cc1a;background-color:#fff}.help-text{margin-top:.75rem;font-size:.9rem;color:var(--text-light);padding:.5rem;background:#f0f7ff;border-radius:.5rem}.quick-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-top:1rem}@media(min-width:768px){.quick-buttons{grid-template-columns:repeat(4,1fr)}}.quick-btn{padding:.5rem;border:2px solid var(--border-color);background:#fff;border-radius:.5rem;cursor:pointer;font-weight:600;transition:all .3s ease}.quick-btn:hover{border-color:var(--primary-color)}.quick-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.recommendations-container{max-width:100%;margin:0 auto;width:100%}.recommendations-header{display:flex;flex-direction:column;gap:1rem;align-items:stretch;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000000d}@media(min-width:768px){.recommendations-header{flex-direction:row;justify-content:space-between;align-items:center;gap:1.5rem}}.header-content{flex:1}.header-buttons{display:flex;flex-direction:column;gap:.75rem}@media(min-width:768px){.header-buttons{flex-direction:row;gap:1rem}}.recommendations-header h2{font-size:1.5rem;margin:0 0 .25rem}@media(min-width:768px){.recommendations-header h2{font-size:2rem}}.recommendation-count{font-size:.9rem;color:var(--text-light);margin:0}.btn-share{background:#10b981;color:#fff;font-size:.9rem;padding:.6rem 1.25rem;width:100%}@media(min-width:768px){.btn-share{width:auto}}.btn-share:hover:not(:disabled){background:#059669;box-shadow:var(--shadow-lg)}.no-results{text-align:center;padding:3rem 2rem;background:#fff;border-radius:1rem;box-shadow:var(--shadow-lg)}.no-results h2{margin-bottom:1rem;color:var(--text-color)}.no-results p{color:var(--text-light);margin-bottom:2rem}.recommendations-list{display:flex;flex-direction:column;gap:2rem}.recommendation-card{background:#fff;border-radius:1rem;padding:2rem;box-shadow:var(--shadow-lg);border-left:4px solid var(--primary-color)}.card-header{display:flex;flex-direction:column;align-items:stretch;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--bg-light)}@media(min-width:768px){.card-header{flex-direction:row;justify-content:space-between;align-items:center;gap:1rem}}.card-title-section{display:flex;flex-direction:column;gap:.5rem;flex:1}.card-header h3{font-size:1.5rem;color:var(--text-color);margin:0}.price-badge{font-size:1.5rem;font-weight:700;color:var(--success-color);background:#ecfdf5;padding:.5rem 1rem;border-radius:.5rem}.warning-box{background:#fffbeb;border:2px solid var(--warning-color);border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.warning-box h4{color:#92400e;margin-bottom:.5rem}.warning-box ul{list-style:none;color:#b45309}.warning-box li{padding:.25rem 0 .25rem 1.5rem;position:relative}.warning-box li:before{content:"⚠️";position:absolute;left:0}.parts-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}@media(min-width:640px){.parts-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.parts-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}.part-item{background:#fff;padding:1.25rem;border-radius:.75rem;border:2px solid var(--border-color);box-shadow:0 1px 3px #0000000d;transition:all .2s ease}.part-item:hover{border-color:var(--primary-color);box-shadow:0 2px 8px #0066cc1a}.part-label{font-size:.75rem;font-weight:700;color:#fff;text-transform:uppercase;margin-bottom:.75rem;background:var(--primary-color);padding:.35rem .75rem;border-radius:.35rem;display:inline-block}.part-name{font-weight:600;color:var(--text-color);margin-bottom:.75rem;line-height:1.3;font-size:.95rem}.part-price{font-size:1.25rem;font-weight:700;color:var(--success-color);margin-bottom:.75rem}.part-explanation{font-size:.8rem;color:#666;margin-bottom:.75rem;font-style:italic;padding:.4rem .5rem;border-left:3px solid var(--primary-color);background:#f5f9ff;border-radius:.3rem}.part-specs{display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem;border-top:1px solid #f0f0f0}.spec-tag{font-size:.85rem;color:var(--text-color);display:grid;grid-template-columns:70px 1fr;gap:.5rem;align-items:baseline;padding:.35rem 0}.spec-tag strong{font-weight:600;color:var(--primary-color);min-width:70px}.scores-section{margin-bottom:2rem}.scores-section h4{font-size:1.1rem;margin-bottom:1rem;color:var(--text-color)}.scores-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}@media(min-width:640px){.scores-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.scores-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.score-item{display:flex;flex-direction:column;gap:.5rem}.score-label{font-weight:600;font-size:.95rem;color:var(--text-color)}.score-bar{height:.5rem;background:var(--border-color);border-radius:.25rem;overflow:hidden}.score-fill{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,#0052a3 100%);transition:width .3s ease}.score-value{font-size:.9rem;font-weight:600;color:var(--text-light)}.breakdown{background:var(--bg-light);padding:1.5rem;border-radius:.5rem}.breakdown h4{font-size:1.1rem;margin-bottom:1rem;color:var(--text-color)}.breakdown-items{display:flex;flex-direction:column;gap:.75rem}.breakdown-item{display:grid;grid-template-columns:1fr;gap:.25rem;align-items:center}@media(min-width:768px){.breakdown-item{grid-template-columns:100px 1fr 150px;gap:1rem}}.breakdown-label{font-weight:600;font-size:.9rem;color:var(--text-color);order:1}.breakdown-bar{height:.5rem;background:#fff;border-radius:.25rem;overflow:hidden;border:1px solid var(--border-color);order:2}.breakdown-fill{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,#0052a3 100%)}.breakdown-amount{text-align:left;font-weight:600;font-size:.9rem;color:var(--text-light);order:3}@media(min-width:768px){.breakdown-label,.breakdown-bar{order:auto}.breakdown-amount{text-align:right;order:auto}}
