*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#2c3e50,#34495e);color:#2c3e50;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 2px 12px #2c3e5014;padding:20px 30px}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.logo h1{color:#2d3748;font-size:28px;font-weight:700;margin-bottom:4px}.logo p{color:#718096;font-size:16px}.header-controls{align-items:center;display:flex;gap:30px}.location-selector,.tier-selector{display:flex;flex-direction:column;gap:6px}.location-selector label,.tier-selector label{color:#4a5568;font-size:14px;font-weight:600}.location-selector select,.tier-selector select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:14px;padding:8px 12px;transition:all .2s}.location-selector select:focus,.tier-selector select:focus{border-color:#1abc9c;box-shadow:0 0 0 3px #1abc9c26;outline:none}.app-main{flex:1 1;margin:0 auto;max-width:1400px;padding:30px;width:100%}.main-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;height:calc(100vh - 200px)}.left-panel,.right-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 24px #2c3e5014;padding:30px}.upload-section h2{color:#2d3748;font-size:24px;font-weight:600;margin-bottom:25px}.dropzone{align-items:center;background:#f7fafc80;border:3px dashed #cbd5e0;border-radius:16px;cursor:pointer;display:flex;justify-content:center;min-height:300px;padding:40px;text-align:center;transition:all .3s ease}.dropzone.active{transform:scale(1.02)}.dropzone.active,.dropzone.has-image{background:#1abc9c0d;border-color:#1abc9c}.dropzone.has-image{min-height:400px;padding:0}.dropzone-content{text-align:center}.dropzone-icon{font-size:64px;margin-bottom:20px;opacity:.7}.dropzone h3{color:#2d3748;font-size:20px;margin-bottom:10px}.dropzone p{color:#718096;font-size:16px;margin-bottom:15px}.dropzone small{color:#a0aec0;font-size:14px}.image-preview{border-radius:12px;height:100%;overflow:hidden;position:relative;width:100%}.image-preview img{height:100%;object-fit:cover;width:100%}.image-overlay{align-items:center;background:#000000b3;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.image-preview:hover .image-overlay{opacity:1}.image-overlay p{font-size:16px;font-weight:500;margin-bottom:15px}.change-btn{background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .2s}.change-btn:hover{background:#ffffff4d;border-color:#ffffff80}.analyze-btn{background:linear-gradient(135deg,#1abc9c,#16a085);border:none;border-radius:12px;box-shadow:0 4px 15px #1abc9c4d;color:#fff;cursor:pointer;font-size:18px;font-weight:600;margin-top:20px;padding:16px 24px;transition:all .3s;width:100%}.analyze-btn:hover:not(:disabled){box-shadow:0 6px 20px #1abc9c66;transform:translateY(-2px)}.analyze-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.analysis-progress{background:#1abc9c0d;border:1px solid #1abc9c1a;border-radius:16px;margin-top:30px;padding:25px}.analysis-progress h3{color:#2d3748;font-size:20px;margin-bottom:8px}.progress-subtitle{color:#718096;font-style:italic;margin-bottom:25px}.steps-container{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.step{align-items:center;background:#ffffffb3;border-radius:10px;display:flex;gap:15px;padding:12px 16px;transition:all .3s}.step.current{animation:pulse 2s infinite;background:#1abc9c1a;border:1px solid #1abc9c33}.step.completed{background:#27ae601a;border:1px solid #27ae6033}.step-icon{font-size:18px;min-width:20px}.step-text{color:#2d3748;font-weight:500}.analysis-time{color:#718096;font-size:14px;font-style:italic;text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.results-section{height:100%;overflow-y:auto}.results-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:25px}.results-header h2{color:#2d3748;font-size:24px;font-weight:600}.ai-badge{background:linear-gradient(135deg,#34495e,#2c3e50);border-radius:20px;font-size:12px;padding:6px 12px}.ai-badge,.export-btn{color:#fff;font-weight:600}.export-btn{background:#1abc9c;border:none;border-radius:8px;cursor:pointer;font-size:14px;padding:10px 16px;transition:all .2s}.export-btn:hover{background:#16a085;transform:translateY(-1px)}.results-content{display:flex;flex-direction:column;gap:20px}.result-card{background:#fffc;border:1px solid #0000000d;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px}.result-card h3{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:18px;font-weight:600;margin-bottom:15px;padding-bottom:8px}.result-card h4{color:#4a5568;font-size:16px;font-weight:600;margin-bottom:10px}.result-card p{color:#718096;line-height:1.6;margin-bottom:15px}.problem-meta{align-items:center;display:flex;gap:15px;margin-top:15px}.severity,.urgency{border-radius:6px;font-size:12px;font-weight:600;padding:4px 8px}.severity.low{background:#c6f6d5;color:#276749}.severity.medium{background:#fefcbf;color:#744210}.severity.high{background:#fed7d7;color:#742a2a}.urgency{background:#e2e8f0;color:#4a5568}.urgency.urgent{background:#fed7d7;color:#742a2a}.cost-summary{margin-bottom:20px}.cost-range{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.cost-range strong{color:#2d3748;font-size:18px}.confidence{color:#718096;font-size:14px}.cost-breakdown{display:flex;flex-direction:column;gap:8px}.breakdown-item{background:#f7fafcb3;border-radius:6px;justify-content:space-between;padding:8px 12px}.breakdown-item,.timeline-info{align-items:center;display:flex}.timeline-info{gap:15px}.timeline-info .days{color:#1abc9c;font-size:24px;font-weight:700}.timeline-info .description{color:#718096}.steps-list{counter-reset:step-counter;list-style:none}.steps-list li{color:#4a5568;counter-increment:step-counter;line-height:1.5;padding:10px 0 10px 40px;position:relative}.steps-list li:before{align-items:center;background:#1abc9c;border-radius:50%;color:#fff;content:counter(step-counter);display:flex;font-size:12px;font-weight:600;height:24px;justify-content:center;left:0;position:absolute;top:10px;width:24px}.tips-list{list-style:none}.tips-list li{color:#4a5568;line-height:1.5;padding:8px 0 8px 25px;position:relative}.tips-list li:before{content:"💡";left:0;position:absolute;top:8px}.ai-details{grid-gap:10px;display:grid;font-size:14px;gap:10px;grid-template-columns:1fr 1fr}.ai-details>div{background:#f7fafcb3;border-radius:6px;color:#4a5568;padding:8px 12px}.no-results{align-items:center;display:flex;height:100%;justify-content:center;text-align:center}.no-results-content{max-width:400px}.no-results-icon{font-size:80px;margin-bottom:20px;opacity:.7}.no-results h3{color:#2d3748;font-size:24px;margin-bottom:15px}.no-results p{color:#718096;line-height:1.6;margin-bottom:25px}.features-list{display:flex;flex-direction:column;gap:10px}.feature{background:#1abc9c0d;border-left:4px solid #1abc9c;border-radius:8px;color:#4a5568;font-weight:500;padding:10px 15px}.app-footer{background:#000c;border-top:1px solid #ffffff1a;color:#ffffffb3;padding:15px 30px}.footer-content{font-size:14px;justify-content:space-between;margin:0 auto;max-width:1400px}.footer-content,.footer-left{align-items:center;display:flex}.footer-left{gap:15px}.footer-right{font-weight:500}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:#1abc9c80;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#1abc9cb3}@media (max-width:1200px){.main-grid{gap:20px;grid-template-columns:1fr}.left-panel{max-height:600px}}.images-preview{width:100%}.images-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:15px}.image-thumbnail{aspect-ratio:1;border:2px solid #fff3;border-radius:8px;overflow:hidden;position:relative}.image-thumbnail img{height:100%;object-fit:cover;width:100%}.image-info{background:#000c;bottom:0;color:#fff;font-size:11px;left:0;padding:5px;position:absolute;right:0;text-align:center}.more-images{background:#ffffff1a;border:2px dashed #ffffff4d;border-radius:8px;color:#ffffffb3;font-size:14px;justify-content:center}.images-summary,.more-images{align-items:center;display:flex}.images-summary{justify-content:space-between;padding:10px 0}.warning-message{background:#ffc10733;border:1px solid #ffc10780;border-radius:8px;color:#856404;font-size:14px;margin-top:15px;padding:10px;text-align:center}.settings-btn{background:#34495e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.settings-btn:hover{background:#2c3e50}.settings-btn:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:80vh;max-width:600px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 30px}.modal-header h3{color:#2d3748;font-size:20px;margin:0}.close-btn{background:none;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;font-size:20px;padding:5px}.close-btn:hover{background:#f7fafc;color:#4a5568}.modal-body{padding:30px}.api-key-section{margin-bottom:25px}.api-key-section label{color:#2d3748;display:block;font-weight:600;margin-bottom:8px}.api-key-section input{border:2px solid #e2e8f0;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.api-key-section input:focus{border-color:#1abc9c;outline:none}.api-key-section small{color:#718096;display:block;font-size:12px;margin-top:5px}.api-info{background:#f7fafc;border-radius:8px;margin-top:20px;padding:20px}.api-info h4{color:#2d3748;margin-bottom:10px}.api-info ul{list-style:none;padding:0}.api-info li{color:#4a5568;font-size:14px;margin-bottom:8px;padding-left:20px;position:relative}.api-info li:before{color:#1abc9c;content:"•";font-weight:700;left:0;position:absolute}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:15px;justify-content:flex-end;padding:20px 30px}.cancel-btn,.save-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.cancel-btn{background:#f7fafc;color:#4a5568}.cancel-btn:hover{background:#edf2f7}.save-btn{background:#1abc9c;color:#fff}.save-btn:hover{background:#16a085}.multi-results{max-height:60vh;overflow-y:auto;padding-right:10px}.result-item{background:#fffffff2;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:20px;padding:20px}.result-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.result-header h3{color:#2d3748;font-size:16px;margin:0}.result-index{background:#34495e;border-radius:12px;color:#fff;font-size:12px;padding:4px 8px}.result-summary-card{background:#f7fafc;border-left:4px solid #1abc9c;border-radius:8px;padding:15px}.result-summary-card h4{color:#2d3748;margin:0 0 10px}.cost-summary,.timeline-summary{color:#4a5568;font-size:14px;margin-bottom:5px}.results-summary{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between}.has-images .dropzone-content{display:none}@media print{.app-footer,.app-header,.left-panel{display:none}.main-grid{grid-template-columns:1fr}.results-section{height:auto;overflow:visible}}.image-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px;padding:0 5px}.images-count{color:#4a5568;font-size:14px;font-weight:500}.clear-all-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s}.clear-all-btn:hover{background:#c82333;transform:translateY(-1px)}.clear-all-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.images-grid.enhanced{gap:15px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-bottom:20px}.image-item{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000f;padding:8px;position:relative;transition:all .3s ease}.image-item:hover{border-color:#1abc9c;box-shadow:0 4px 15px #1abc9c26;transform:translateY(-2px)}.image-item.analyzing{background:#ffc1070d;border-color:#ffc107}.image-item.completed{background:#28a7450d;border-color:#28a745}.image-item.error{background:#dc35450d;border-color:#dc3545}.image-preview-container{aspect-ratio:1;border-radius:8px;cursor:pointer;margin-bottom:10px;overflow:hidden;position:relative}.image-preview-container img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.image-preview-container:hover img{transform:scale(1.05)}.image-remove-btn{align-items:center;background:#dc3545e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;height:24px;justify-content:center;opacity:0;position:absolute;right:5px;top:5px;transition:all .2s ease;width:24px}.image-item:hover .image-remove-btn{opacity:1}.image-remove-btn:hover{background:#dc3545;transform:scale(1.1)}.image-status-indicator{align-items:center;border:2px solid #fff;border-radius:50%;bottom:5px;display:flex;font-size:10px;font-weight:700;height:20px;justify-content:center;left:5px;position:absolute;width:20px}.image-status-indicator.pending{background:#6c757d;color:#fff}.image-status-indicator.analyzing{animation:pulse-slow 1.5s infinite;background:#ffc107;color:#212529}.image-status-indicator.completed{background:#28a745;color:#fff}.image-status-indicator.error{background:#dc3545;color:#fff}@keyframes pulse-slow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.image-name-container{align-items:center;display:flex;justify-content:center;min-height:35px}.image-name{border-radius:4px;color:#2d3748;cursor:pointer;font-size:12px;font-weight:500;line-height:1.3;padding:4px 8px;text-align:center;transition:all .2s;word-break:break-word}.image-name:hover{background:#1abc9c1a;color:#1abc9c}.image-name-edit{background:#fff;border:2px solid #1abc9c;border-radius:4px;font-size:12px;outline:none;padding:4px 6px;text-align:center;width:100%}.image-name-edit:focus{box-shadow:0 0 0 2px #1abc9c33}.image-preview-modal{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.preview-modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000080;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;overflow:hidden}.preview-modal-header{align-items:center;background:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 25px}.preview-modal-title{color:#2d3748;font-size:18px;font-weight:600;margin:0}.preview-close-btn{background:none;border:none;border-radius:6px;color:#a0aec0;cursor:pointer;font-size:24px;padding:5px 10px;transition:all .2s}.preview-close-btn:hover{background:#e2e8f0;color:#4a5568}.preview-modal-body{display:flex;flex:1 1;min-height:0}.preview-image-container{align-items:center;background:#f7fafc;display:flex;flex:1 1;justify-content:center;padding:20px}.preview-image{border-radius:8px;box-shadow:0 8px 25px #00000026;max-height:100%;max-width:100%;object-fit:contain}.preview-details{background:#fff;border-left:1px solid #e2e8f0;overflow-y:auto;padding:25px;width:320px}.preview-details h3{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:16px;font-weight:600;margin-bottom:20px;padding-bottom:10px}.detail-group{margin-bottom:20px}.detail-label{color:#4a5568;display:block;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.detail-value{color:#2d3748;font-size:14px;font-weight:500}.detail-value.editable{border:1px solid #0000;border-radius:4px;cursor:pointer;padding:6px 8px;transition:all .2s}.detail-value.editable:hover{background:#f7fafc;border-color:#e2e8f0}.status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:600;gap:5px;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status-badge.pending{background:#e2e8f0;color:#4a5568}.status-badge.analyzing{background:#fff3cd;color:#856404}.status-badge.completed{background:#d4edda;color:#155724}.status-badge.error{background:#f8d7da;color:#721c24}.preview-actions{border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:10px;margin-top:25px;padding-top:20px}.preview-action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px 16px;transition:all .2s;width:100%}.preview-action-btn.remove{background:#dc3545;color:#fff}.preview-action-btn.remove:hover{background:#c82333}.preview-action-btn.reanalyze{background:#ffc107;color:#212529}.preview-action-btn.reanalyze:hover{background:#e0a800}.preview-action-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.preview-modal-body{flex-direction:column}.preview-details{border-left:none;border-top:1px solid #e2e8f0;width:100%}.preview-image-container{min-height:300px}.images-grid.enhanced{gap:10px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.image-item{padding:6px}.image-name{font-size:11px}}.upload-section.has-images h2{margin-bottom:15px}.upload-section.has-images .analyze-btn{margin-top:15px}
/*# sourceMappingURL=main.f86b84f4.css.map*/