.app-container{flex-direction:column;width:100vw;height:calc(100vh - 64px);display:flex;overflow:hidden}.main-content{flex:1;min-height:0;display:flex;overflow:hidden}.sidebar{box-sizing:border-box;background:#f5f5f5;border-right:1px solid #ddd;width:450px;padding:20px;overflow-y:auto}.comp-analysis-section{margin-top:20px;margin-bottom:20px}.sidebar h1{color:#333;margin-top:0;font-size:1.5rem}.property-search{background:#fff;border:1px solid #ddd;border-radius:8px;margin-bottom:20px;padding:15px}.property-search label{color:#333;margin-bottom:8px;font-size:14px;font-weight:600;display:block}.search-input-wrapper{gap:8px;display:flex}.search-input-wrapper input{border:1px solid #ccc;border-radius:4px;flex:1;padding:8px 12px;font-family:monospace;font-size:13px}.search-input-wrapper input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 2px #667eea33}.search-input-wrapper button:focus-visible,.main-tab:focus-visible{outline-offset:2px;outline:2px solid #667eea}.search-input-wrapper button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:4px;padding:8px 16px;font-weight:600;transition:background .2s}.search-input-wrapper button:hover:not(:disabled){background:#5568d3}.search-input-wrapper button:disabled{cursor:not-allowed;background:#ccc}.search-error{color:#c62828;background:#ffebee;border-radius:4px;margin-top:8px;padding:8px;font-size:13px}.file-selector{margin-bottom:20px}.file-selector label{color:#555;margin-bottom:8px;font-weight:600;display:block}.file-selector select{appearance:none;background:#fff url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E") right 12px center no-repeat;border:1px solid #ccc;border-radius:4px;width:100%;padding:8px 32px 8px 12px;font-size:14px}.status{color:#1976d2;background:#e3f2fd;border-radius:4px;margin-bottom:10px;padding:10px}.error{color:#c62828;background:#ffebee;border-radius:4px;margin-bottom:10px;padding:10px}.file-info{background:#fff;border:1px solid #ddd;border-radius:4px;padding:15px}.file-info h2{color:#333;margin-top:0;font-size:1.2rem}.file-info h3{color:#555;margin-top:15px;font-size:1rem}.file-info p{color:#666;margin:8px 0;font-size:14px}.file-info strong{color:#333}.properties{text-align:left;white-space:pre-wrap;word-break:break-word;background:#f8f8f8;border:1px solid #e0e0e0;border-radius:4px;max-height:300px;padding:10px;font-size:12px;overflow-y:auto}.map-container{background:#e0e0e0;flex:1;min-height:0;position:relative}.map-container canvas{width:100%!important;height:100%!important}.map-placeholder{background:#f0f0f0;justify-content:center;align-items:center;height:100%;display:flex}.map-placeholder p{color:#666;font-size:1.1rem}.attribution{background:#fffc;border-radius:4px;padding:4px 8px;font-size:12px;position:absolute;bottom:10px;right:10px}.attribution a{color:#06c;text-decoration:none}.attribution a:hover{text-decoration:underline}.validation-status{background:#f0f8ff;border:1px solid #d0e0f0;border-radius:4px;margin-top:15px;padding:10px}.validation-status h3{color:#2c5282;margin-top:0;margin-bottom:10px}.validation-status p{margin:5px 0;font-size:13px}.validation-status .valid{color:#22543d}.validation-status .invalid{color:#742a2a}.hovered-property-info{background:#fff;border:2px solid #4caf50;border-radius:4px;margin-top:20px;padding:15px;box-shadow:0 2px 4px #0000001a}.hovered-property-info h2{color:#2e7d32;border-bottom:1px solid #e0e0e0;margin-top:0;margin-bottom:12px;padding-bottom:8px;font-size:1.1rem}.property-details{font-size:14px}.geometry-info{border-top:1px solid #e0e0e0;margin-top:10px;padding-top:10px}.geometry-info p{color:#555;margin:5px 0;font-size:13px}.geometry-info strong{color:#333}.distance-control{background:#fff;border:1px solid #ddd;border-radius:4px;margin:20px 0;padding:15px}.distance-control label{color:#333;cursor:pointer;align-items:center;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.distance-control input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin-right:8px}.distance-control input[type=range]{appearance:none;background:#ddd;border-radius:3px;outline:none;width:100%;height:6px}.distance-control input[type=range]::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#4caf50;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 4px #0003}.distance-control input[type=range]::-moz-range-thumb{cursor:pointer;background:#4caf50;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 4px #0003}.distance-control input[type=range]:hover::-webkit-slider-thumb{background:#45a049}.distance-control input[type=range]:hover::-moz-range-thumb{background:#45a049}.distance-info{margin-top:8px}.distance-info small{color:#666;font-size:12px}.nearby-count{color:#1565c0;background:#e3f2fd;border:1px solid #90caf9;border-radius:4px;margin:10px 0;padding:8px;font-size:14px}.nearby-count strong{color:#0d47a1;font-weight:700}.street-control{background:#fff;border:1px solid #ddd;border-radius:4px;margin:20px 0;padding:15px}.street-control label{color:#333;cursor:pointer;align-items:center;font-size:14px;font-weight:600;display:flex}.street-control input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin-right:8px}.street-info{margin-top:8px;padding-left:24px}.street-info small{color:#666;font-size:12px}.hovered-street-info{background:#fff;border:2px solid #ffc107;border-radius:4px;margin-top:20px;padding:15px;box-shadow:0 2px 4px #0000001a}.hovered-street-info h2{color:#f57c00;border-bottom:1px solid #e0e0e0;margin-top:0;margin-bottom:12px;padding-bottom:8px;font-size:1.1rem}.street-details{font-size:14px}.street-details p{color:#555;margin:5px 0}.street-details strong{color:#333}.comps-control{background:#fff;border:1px solid #ddd;border-radius:4px;margin:20px 0;padding:15px}.comps-control label{color:#333;cursor:pointer;align-items:center;font-size:14px;font-weight:600;display:flex}.comps-control input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin-right:8px}.comps-control input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.comps-info{margin-top:8px;padding-left:24px}.comps-info small{color:#666;font-size:12px}.comps-list{background:#fff;border:2px solid #2196f3;border-radius:4px;max-height:600px;margin-top:20px;padding:15px;overflow-y:auto;box-shadow:0 2px 4px #0000001a}.comps-list h2{color:#1976d2;border-bottom:2px solid #e3f2fd;margin-top:0;margin-bottom:12px;padding-bottom:8px;font-size:1.1rem}.comps-list h3{color:#555;margin-top:15px;margin-bottom:8px;font-size:.95rem}.selected-property-info{background:#f0f8ff;border-radius:4px;margin-bottom:15px;padding:10px}.selected-property-info p{color:#333;margin:5px 0;font-size:13px}.comp-criteria{background:#f5f5f5;border-radius:4px;margin-bottom:15px;padding:10px}.comp-criteria ul{margin:0;padding-left:20px;list-style:none}.comp-criteria li{color:#4caf50;margin:4px 0;font-size:13px}.comp-properties-list{margin-top:15px}.comp-items{max-height:300px;overflow-y:auto}.comp-item{background:#fafafa;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:8px;padding:8px;font-size:13px;transition:background-color .2s}.comp-item:hover{background:#e3f2fd;border-color:#90caf9}.comp-address{color:#333;margin-bottom:4px;font-weight:500}.comp-match-details{color:#666;align-items:center;gap:8px;font-size:12px;display:flex}.parcel-id{color:#888;font-size:11px}.match-indicator{border-radius:3px;margin-right:8px;padding:2px 6px;display:inline-block}.match-indicator.match{color:#2e7d32;background:#e8f5e9;border:1px solid #a5d6a7}.match-indicator.no-match{color:#c62828;background:#ffebee;border:1px solid #ef9a9a}.more-comps{color:#666;text-align:center;background:#f5f5f5;border-radius:4px;margin-top:10px;padding:8px;font-size:12px;font-style:italic}.main-tabs{background:#2c3e50;flex-shrink:0;gap:0;padding:0 20px;display:flex}.main-tab{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;align-items:center;gap:10px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.main-tab:hover{color:#fff;background:#ffffff1a}.main-tab.active{color:#fff;background:#667eea33;border-bottom-color:#667eea}.main-tab .tab-count{color:#fff;background:#fff3;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.main-tab.active .tab-count{background:#667eea}.comparison-table-fullscreen{background:#fff;flex:1;overflow:hidden}.map-options-section{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;margin-top:20px;padding:15px}.map-options-section h3{color:#666;text-transform:uppercase;letter-spacing:.5px;margin:0 0 15px;font-size:14px}.map-options-section .distance-control,.map-options-section .street-control,.map-options-section .comps-control{background:#fff;margin:0 0 10px;padding:10px}
