:root{--primary-color: #E53E3E;--primary-hover-color: #C53030;--primary-light-color: rgba(229, 62, 62, .15);--danger-color: #E53E3E;--danger-hover-color: #C53030;--text-color: #E2E8F0;--text-muted-color: #A0AEC0;--background-color: #1A202C;--light-gray-color: #2D3748;--border-color: #4A5568;--heading-font: "Poppins", "Segoe UI", "Helvetica Neue", sans-serif;--body-font: "Roboto", "Segoe UI", system-ui, sans-serif}body{font-family:var(--body-font);line-height:1.6;color:var(--text-color);background-color:var(--background-color);margin:0;padding:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container{max-width:1100px;margin:0 auto;padding:0 1.5em}.navbar{background:var(--background-color);box-shadow:0 2px 4px #0003;border-bottom:1px solid var(--border-color);padding:1em 0;position:sticky;top:0;z-index:1000}.shared-view-active .navbar{display:none}.navbar .container{display:flex;justify-content:space-between;align-items:center}.logo{font-family:var(--heading-font);font-size:1.5rem;font-weight:800;color:var(--primary-color);text-decoration:none}.nav-links{display:flex;gap:1em;align-items:center}.nav-links .btn-secondary{padding:.6em 1.2em;font-weight:500}.nav-link{font-family:var(--heading-font);font-size:1rem;font-weight:600;color:var(--text-color);background:none;border:none;cursor:pointer;text-decoration:none;padding:.25em;transition:color .2s ease-in-out}.nav-link:hover{color:var(--primary-color)}.btn{font-family:var(--heading-font);font-size:1rem;padding:.75em 1.5em;border-radius:8px;border:2px solid var(--primary-color);cursor:pointer;transition:all .2s ease-in-out;font-weight:600;background-color:transparent;color:var(--primary-color);display:inline-flex;align-items:center;justify-content:center;gap:.5em}.btn:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #e53e3e33}.btn:disabled{background-color:var(--border-color);border-color:var(--border-color);color:var(--text-muted-color);cursor:not-allowed;transform:none;box-shadow:none}.btn.loading{cursor:wait}.btn-spinner{display:inline-block;width:1em;height:1em;border:2px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:.5em;position:relative;top:-1px}.btn-secondary.loading .btn-spinner,.btn-icon.loading .btn-spinner{border-color:#e2e8f04d;border-top-color:var(--text-color)}.btn-primary{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover-color);border-color:var(--primary-hover-color)}.btn-primary:disabled{background-color:#c530305e;border-color:#c530305e}.btn-secondary{background-color:transparent;color:var(--text-muted-color);border-color:var(--border-color)}.btn-secondary:hover{background-color:var(--light-gray-color);border-color:var(--border-color);color:var(--text-color);box-shadow:0 4px 12px #0003}.btn-secondary:disabled{background-color:transparent;border-color:var(--border-color);color:var(--border-color)}.btn-danger{background-color:transparent;color:var(--danger-color);border-color:var(--danger-color)}.btn-danger:hover{background-color:var(--danger-color);color:#fff;border-color:var(--danger-color)}.btn-large{font-size:1.1rem;padding:.9em 2.2em}.btn-link{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;padding:0;font-size:.9rem;font-weight:600}.btn-link:hover{color:var(--primary-hover-color)}.btn-icon{background:var(--light-gray-color);border:1px solid var(--border-color);color:var(--text-muted-color);border-radius:8px;padding:0;width:48px;height:48px;display:inline-flex;justify-content:center;align-items:center;cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--border-color);color:var(--text-color)}.btn-icon .btn-spinner{margin:0;width:20px;height:20px}.btn-icon svg{transition:transform .2s ease}.btn-icon:hover svg{transform:scale(1.1)}.hero{text-align:center;padding:6em 0;background-color:var(--background-color)}.hero h1{font-family:var(--heading-font);font-size:3.5rem;font-weight:800;margin-bottom:.5em;color:var(--text-color);line-height:1.2}.hero .subtitle{font-size:1.25rem;max-width:600px;margin:0 auto 2.5em;color:var(--text-muted-color)}.features{padding:5em 0;text-align:center}.features h2{font-family:var(--heading-font);font-size:2.8rem;font-weight:800;margin-bottom:2em;color:var(--text-color)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2em;text-align:left}.feature-card{background:var(--light-gray-color);border:1px solid var(--border-color);border-radius:12px;padding:2.5em;box-shadow:0 4px 8px #0000001a;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.feature-card h3{font-family:var(--heading-font);font-size:1.5rem;font-weight:700;margin-top:0;color:var(--primary-color)}.pricing{padding:5em 0;background-color:var(--background-color);text-align:center}.pricing h2{font-family:var(--heading-font);font-size:2.8rem;font-weight:800;margin-bottom:.5em;color:var(--text-color)}.pricing-subtitle{font-size:1.15rem;color:var(--text-muted-color);margin-bottom:3em}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2em;align-items:center}.pricing-card{background:var(--light-gray-color);border:1px solid var(--border-color);border-radius:12px;padding:2.5em;text-align:left;position:relative;transition:transform .2s,box-shadow .2s}.pricing-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0003}.pricing-card.popular{border-color:var(--primary-color);border-width:2px;transform:scale(1.05)}.popular-badge{position:absolute;top:-15px;left:50%;transform:translate(-50%);background:var(--primary-color);color:#fff;padding:.4em 1em;border-radius:50px;font-size:.9rem;font-weight:600}.pricing-card h3{font-family:var(--heading-font);font-size:1.6rem;font-weight:700;color:var(--text-color)}.pricing-card .price{margin:1em 0;color:var(--text-muted-color)}.pricing-card .price span{font-size:3rem;font-weight:800;color:var(--text-color)}.pricing-card-description{min-height:48px;color:var(--text-muted-color);margin-bottom:2em}.pricing-card ul{list-style:none;padding:0;margin:2em 0}.pricing-card ul li{margin-bottom:1em;padding-left:1.5em;position:relative}.pricing-card ul li:before{content:"✓";color:var(--primary-color);position:absolute;left:0;font-weight:700}.pricing-card .btn{width:100%;margin-top:1em;display:inline-block;box-sizing:border-box}.footer{background:#000;text-align:center;padding:2em 0;color:#a0aec0;border-top:1px solid var(--border-color)}.shared-view-active .footer{display:none}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000;opacity:1;transition:opacity .3s ease}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal{background:var(--light-gray-color);padding:2.5em;border-radius:12px;width:90%;max-width:400px;box-shadow:0 5px 15px #00000080;position:relative;border:1px solid var(--border-color)}.modal-close-btn{position:absolute;top:10px;right:15px;font-size:1.8rem;background:none;border:none;cursor:pointer;color:var(--text-muted-color)}.modal h2{font-family:var(--heading-font);font-weight:700;margin-top:0;text-align:center}#share-link-input{background-color:var(--background-color);color:var(--text-muted-color);font-size:.9rem}.form-group{margin-bottom:1.2em}.form-group label{display:block;margin-bottom:.5em;font-weight:600}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.8em;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;font-family:var(--body-font);box-sizing:border-box;background-color:var(--background-color);color:var(--text-color);transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light-color)}.error-message{color:var(--danger-color);font-size:.875rem;margin-top:.4em;min-height:1.2em}.form-group input.invalid{border-color:var(--danger-color)}.form-group input.invalid:focus{border-color:var(--danger-color);box-shadow:0 0 0 3px #e53e3e33}.btn-full-width{width:100%}.report-generator-view{padding:4em 0;text-align:center;background-image:linear-gradient(#1a202cf2,#1a202cf2),radial-gradient(var(--light-gray-color) 1px,transparent 1px);background-size:100%,20px 20px}.address-form-container{background:var(--light-gray-color);padding:2.5em;border-radius:12px;max-width:650px;margin:0 auto;border:1px solid var(--border-color);box-shadow:0 8px 25px #0003}.address-form-container h1{font-family:var(--heading-font);font-weight:700;margin-top:0}.address-form-container p{color:var(--text-muted-color);margin-bottom:2em}.address-form-container .form-group{text-align:left}.address-input-group{display:flex;gap:.5em;align-items:center}.address-input-wrapper{position:relative;flex-grow:1}#address-input-icon{position:absolute;left:1em;top:50%;transform:translateY(-50%);color:var(--text-muted-color);pointer-events:none}#address-input{font-size:1.1rem;padding:.8em 1em .8em 2.8em;height:48px}.address-input-wrapper input:focus+#address-input-icon{color:var(--primary-color)}.recent-searches-container{margin-top:2.5em;padding-top:1.5em;border-top:1px solid var(--border-color);text-align:left}.recent-searches-container h3{font-size:1rem;font-weight:600;color:var(--text-muted-color);margin:0 0 1em}.recent-searches-list{display:flex;flex-wrap:wrap;gap:.75em}.recent-search-item{background:var(--background-color);border:1px solid var(--border-color);color:var(--text-color);padding:.5em 1em;border-radius:50px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.recent-search-item:hover{background-color:var(--light-gray-color);border-color:var(--text-muted-color);transform:translateY(-2px)}.loading-view{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:400px;text-align:center}.spinner{border:6px solid var(--light-gray-color);border-top:6px solid var(--primary-color);border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:1.5em}.loading-view p{font-size:1.2rem;font-weight:600;color:var(--text-color)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.report-view{padding:3em 0;opacity:0;animation:fadeIn .5s forwards}.shared-view-header{background-color:var(--background-color);padding:1em;text-align:center;border-bottom:1px solid var(--border-color);margin-bottom:2em}.shared-view-header p{margin:0;font-size:1.1rem;font-weight:600}.shared-view-header a{color:var(--primary-color);font-weight:700;text-decoration:none}@keyframes fadeIn{to{opacity:1}}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:2.5em;text-align:left;margin-bottom:3em}.report-image-container{border:1px solid var(--border-color);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0003}.report-image-container img{width:100%;display:block}.report-image-container p{padding:1em;background:var(--light-gray-color);margin:0;font-weight:600;border-top:1px solid var(--border-color)}.report-details-container h2{font-family:var(--heading-font);font-size:1.8rem;margin-top:0;margin-bottom:1em;color:var(--primary-color);border-bottom:2px solid var(--border-color);padding-bottom:.5em}.roof-visualization-container{border:1px solid var(--border-color);border-radius:8px;padding:1em;margin-bottom:1.5em;background-color:var(--background-color);overflow:hidden}.roof-visualization-container svg{width:100%;height:auto;display:block}.roof-visualization-container text{font-family:var(--body-font)!important}.measurements-table{width:100%;border-collapse:collapse}.measurements-table th,.measurements-table td{padding:.8em 1em;text-align:left;border-bottom:1px solid var(--border-color);vertical-align:middle}.measurements-table th{background-color:var(--light-gray-color);font-weight:600}.measurements-table tr:last-child td{border-bottom:none}.measurements-table tr:nth-child(2n){background-color:var(--light-gray-color)}.measurement-input{width:100%;padding:.5em;font-size:1rem;font-family:var(--body-font);border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;background-color:var(--background-color);color:var(--text-color)}.measurement-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #e53e3e33}.measurements-table .drag-handle-row{cursor:grab;color:var(--text-muted-color);padding:0 .75em 0 .25em;font-size:1.2rem;opacity:.5;transition:opacity .2s}.measurements-table tr:hover .drag-handle-row{opacity:1}.measurements-table .visibility-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25em;opacity:.6}.measurements-table .visibility-toggle:hover{opacity:1}.measurements-table tr.row-hidden{opacity:.4;background-color:#1a202c!important}.measurements-table tr.row-hidden .measurement-value,.measurements-table tr.row-hidden .measurement-input{text-decoration:line-through}.measurements-table tr.dragging{opacity:.5;background:var(--primary-color)}#visualization-controls{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:8px;padding:1.2em;margin-bottom:1.5em}.vis-controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1em}#visualization-controls h4{margin:0;font-family:var(--heading-font)}.vis-controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1em}.vis-control{display:flex;flex-direction:column;gap:.5em}.vis-control label{font-size:.9rem;font-weight:500}.vis-control input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:44px;background-color:transparent;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:border-color .2s,box-shadow .2s;background-image:linear-gradient(45deg,var(--background-color) 25%,transparent 25%),linear-gradient(-45deg,var(--background-color) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--background-color) 75%),linear-gradient(-45deg,transparent 75%,var(--background-color) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px}.vis-control input[type=color]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light-color)}.vis-control input[type=color]::-webkit-color-swatch{border-radius:5px;border:none}.vis-control input[type=color]::-moz-color-swatch{border-radius:5px;border:none}.report-actions{text-align:center;margin-top:3em;display:flex;flex-wrap:wrap;justify-content:center;gap:1.5em;align-items:center}.segments-title{font-family:var(--heading-font);font-size:1.5rem;margin-top:2em;margin-bottom:1em;color:var(--text-muted-color);border-bottom:1px solid var(--border-color);padding-bottom:.5em}.segments-table{margin-bottom:1.5em}.segments-table th{background-color:var(--background-color);font-weight:500}.history-view{padding:3em 0}.view-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5em}.history-view h1{font-family:var(--heading-font);font-size:2.5rem;font-weight:800;text-align:center;margin:0;color:var(--text-color)}.view-header h1{text-align:left}.history-search-container{max-width:500px;margin:0 auto 2.5em;position:relative}#history-search-input{width:100%;padding:.8em 1em .8em 2.5em;font-size:1rem;border:1px solid var(--border-color);border-radius:50px;box-sizing:border-box;background-color:var(--light-gray-color);color:var(--text-color);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23A0AEC0' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:1em center;transition:box-shadow .2s}#history-search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #e53e3e33}.history-grid,.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5em}.history-card,.template-card{border:1px solid var(--border-color);border-radius:12px;background:var(--light-gray-color);box-shadow:0 4px 8px #00000026;transition:transform .2s,box-shadow .2s;overflow:hidden;display:flex;flex-direction:column}.history-card:hover,.template-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000040}.history-card-img-container{height:180px;background-color:var(--background-color)}.history-card img{width:100%;height:100%;object-fit:cover}.history-card-content,.template-card-content{padding:1.2em;flex-grow:1;display:flex;flex-direction:column}.history-card-content h3,.template-card-content h3{font-family:var(--heading-font);font-size:1.1rem;font-weight:600;margin:0 0 .5em;line-height:1.4}.profile-view{padding:3em 0}.profile-form-container{max-width:700px;margin:0 auto;padding:2.5em;background:var(--light-gray-color);border:1px solid var(--border-color);border-radius:12px}.profile-form-container h1{margin-top:0;font-family:var(--heading-font)}.logo-preview-container{min-height:80px;border:2px dashed var(--border-color);border-radius:8px;display:flex;justify-content:center;align-items:center;margin-bottom:1em;padding:1em}.logo-preview-img{max-width:150px;max-height:80px}.logo-placeholder{color:var(--text-muted-color)}.hidden-file-input{display:none}.form-actions{display:flex;justify-content:flex-end;gap:1em;margin-top:2em;padding-top:1.5em;border-top:1px solid var(--border-color)}#custom-sections-list{display:flex;flex-direction:column;gap:.75em;margin-bottom:1.5em;min-height:50px;border:1px solid var(--border-color);border-radius:8px;padding:.75em;background-color:var(--background-color)}.custom-section-item{display:flex;align-items:center;background-color:var(--light-gray-color);border:1px solid var(--border-color);border-radius:6px;padding:.5em .8em;transition:background-color .2s,box-shadow .2s}.custom-section-item .drag-handle{cursor:grab;color:var(--text-muted-color);font-size:1.5rem;line-height:1;margin-right:.5em;-webkit-user-select:none;user-select:none;transition:color .2s}.custom-section-item:hover .drag-handle{color:var(--text-color)}.custom-section-item.dragging{opacity:.5;background:var(--primary-light-color);border-style:dashed;border-color:var(--primary-color)}body.dragging-active{cursor:grabbing!important}.section-title-text{flex-grow:1;padding:.3em 0}.section-title-input{flex-grow:1}.section-item-actions{display:flex;gap:.5em}.section-item-actions button{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--text-muted-color);padding:.2em .4em}.section-item-actions .btn-remove-section:hover{color:var(--danger-color)}.section-item-actions .btn-edit-section:hover,.section-item-actions .btn-save-section:hover{color:var(--primary-color)}.add-section-container{border:1px solid var(--border-color);border-radius:8px;padding:1.2em;margin-top:1em}.add-section-label{font-weight:600;margin-bottom:.75em;display:block}.quick-add-pills{display:flex;flex-wrap:wrap;gap:.5em;margin-bottom:1em}.quick-add-pill{background:var(--background-color);border:1px solid var(--border-color);color:var(--text-muted-color);border-radius:50px;padding:.4em 1em;font-size:.9rem;cursor:pointer;transition:all .2s}.quick-add-pill:hover{background:var(--light-gray-color);color:var(--text-color);border-color:var(--text-muted-color)}.custom-add-section{display:flex;gap:.5em}.custom-add-section input{flex-grow:1}.pac-container{background-color:var(--light-gray-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #0000004d;z-index:2001!important;font-family:var(--body-font)}.pac-item{padding:10px;font-size:1rem;color:var(--text-color);cursor:pointer;border-top:1px solid var(--border-color)}.pac-container .pac-item:first-child{border-top:none}.pac-item:hover{background-color:var(--background-color)}.pac-item-query{font-size:1rem;color:var(--text-color)}.pac-matched{font-weight:600;color:var(--primary-color)}.pac-logo:after{background-image:url(https://maps.gstatic.com/mapfiles/api-3/images/powered-by-google-dark.png)!important;background-size:100px 12px!important}
