:root{font-family:system-ui,-apple-system,sans-serif;color-scheme:light}body{margin:0;padding:1.5rem;background:#f8fafc;color:#1e293b;font-size:.9rem}.crrem-header{display:flex;align-items:center;justify-content:space-between;gap:2rem;margin-bottom:1.75rem}.crrem-header-left{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.crrem-logo{height:3rem;width:auto;display:block}.crrem-app h1{font-size:1.4rem;font-weight:600;margin:0;color:#0f172a}.crrem-header-cta{font-size:.82rem;color:#64748b;line-height:1.5;margin:0;text-align:right;max-width:480px}.crrem-header-cta a{color:#2563eb;font-weight:500;text-decoration:none;white-space:nowrap}.crrem-header-cta a:hover{text-decoration:underline}.options-bar-row{display:flex;align-items:center;gap:.75rem}.options-bar-row .options-bar{flex:1}.options-bar-io{display:flex;gap:.4rem;flex-shrink:0}.btn-io{padding:.38rem .85rem;border-radius:5px;font-size:.82rem;font-weight:500;cursor:pointer;background:#fff;border:1px solid #cbd5e1;color:#475569;transition:background .12s,border-color .12s;white-space:nowrap}.btn-io:hover{background:#f1f5f9;border-color:#94a3b8}.import-error{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.6rem .85rem;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;color:#b91c1c;font-size:.82rem}.import-error strong{font-weight:600}.import-error-close{margin-left:auto;border:none;background:none;color:#ef4444;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .15rem;border-radius:3px;flex-shrink:0}.import-error-close:hover{background:#fee2e2}.tab-bar{display:flex;gap:0;border-bottom:2px solid #e2e8f0;margin-bottom:1.5rem}.tab-btn{padding:.5rem 1.5rem;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;background:none;font-size:.88rem;font-weight:500;color:#64748b;cursor:pointer;transition:color .15s,border-color .15s}.tab-btn:hover{color:#1e293b}.tab-btn--active{color:#2563eb;border-bottom-color:#2563eb}.inputs-layout{display:flex;flex-direction:column;gap:1.25rem}.options-bar{display:flex;align-items:center;gap:1.5rem;background:#e9edf2;border:1px solid #d1d9e0;border-radius:8px;padding:.6rem 1.1rem;flex-wrap:wrap}.options-bar-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#64748b;white-space:nowrap;margin-right:.25rem}.options-field{display:flex;align-items:center;gap:.45rem}.options-field>span{font-size:.78rem;font-weight:500;color:#475569;white-space:nowrap}.options-field select{padding:.28rem .5rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.82rem;background:#fff;color:#1e293b;cursor:pointer}.options-field select:focus{outline:2px solid #3b82f6;outline-offset:1px;border-color:transparent}.graph-layout{display:grid;grid-template-columns:1fr 220px;gap:1.5rem;align-items:start}.graph-main{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.summary-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.875rem 1rem 1rem}.buildings-table-wrap{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.75rem;box-shadow:0 1px 4px #0000000f}.buildings-table-header{display:flex;align-items:center;justify-content:space-between}.buildings-table-scroll{overflow-x:auto}.buildings-table{width:100%;border-collapse:collapse;font-size:.83rem}.buildings-table th{text-align:left;font-size:.75rem;font-weight:600;color:#64748b;letter-spacing:.02em;padding:.4rem .5rem;border-bottom:2px solid #e2e8f0;white-space:nowrap}.buildings-table td{padding:.35rem .5rem;vertical-align:middle;border-bottom:1px solid #f1f5f9}.buildings-table tbody tr:hover td{background:#f8fafc}.buildings-table input,.buildings-table select{padding:.28rem .4rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.82rem;background:#fff;color:#1e293b;box-sizing:border-box;width:100%}.buildings-table input:focus,.buildings-table select:focus{outline:2px solid #3b82f6;outline-offset:1px;border-color:transparent}.col-index{color:#94a3b8;font-size:.75rem;text-align:center;width:2rem}.col-name{min-width:130px}.col-use-type{min-width:180px}.col-number{width:130px}.col-remove{width:2rem;text-align:center}.col-retrofit-hdr,.col-retrofit-check{text-align:center;width:5rem}.col-retrofit-check input[type=checkbox]{width:1rem;height:1rem;cursor:pointer;accent-color:#2563eb}.col-locked{background:#f8fafc}.locked-dash{display:block;text-align:center;color:#cbd5e1;font-size:.9rem;-webkit-user-select:none;user-select:none}.row-retrofitted td{background:#eff6ff}.row-retrofitted:hover td{background:#dbeafe}.unit-toggle-group{display:flex;align-items:center;gap:.4rem}.unit-toggle-label{font-size:.78rem;font-weight:500;color:#475569;white-space:nowrap}.unit-toggle{display:inline-flex;align-items:center;background:#e2e8f0;border-radius:5px;padding:2px;gap:0}.unit-opt{padding:.22rem .6rem;border:none;background:transparent;border-radius:3px;font-size:.78rem;font-weight:500;color:#64748b;cursor:pointer;transition:color .15s;line-height:1.4}.unit-opt--active{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001f}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#64748b;margin:0 0 .25rem;display:flex;align-items:center;gap:.5rem}.zone-count{display:inline-flex;align-items:center;justify-content:center;width:1.3em;height:1.3em;border-radius:999px;background:#e2e8f0;color:#475569;font-size:.75rem;font-weight:600}.field{display:flex;flex-direction:column;gap:.2rem}.field>span{font-size:.78rem;font-weight:500;color:#475569}.field input,.field select{padding:.3rem .45rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.85rem;background:#fff;color:#1e293b;width:100%;box-sizing:border-box}.field input:focus,.field select:focus{outline:2px solid #3b82f6;outline-offset:1px;border-color:transparent}.field-sm{margin-top:.5rem}.field-hint{font-style:normal;color:#94a3b8;font-weight:400}.info-tip{position:relative;display:inline-flex;align-items:center;margin-left:.3em;color:#94a3b8;font-size:.8rem;cursor:default;vertical-align:middle}.info-tip:hover{color:#3b82f6}.info-tip-text{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);width:220px;padding:.5rem .65rem;background:#1e293b;color:#f1f5f9;font-size:.75rem;font-weight:400;line-height:1.4;border-radius:6px;box-shadow:0 4px 12px #0003;pointer-events:none;z-index:10;white-space:normal}.info-tip-text:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#1e293b}.info-tip:hover .info-tip-text{display:block}.btn-remove-zone{border:none;background:none;color:#94a3b8;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 .15rem;border-radius:3px;transition:color .1s,background .1s}.btn-remove-zone:hover{color:#ef4444;background:#fee2e2}.btn-add-zone{margin-top:.25rem;padding:.4rem .75rem;border:1px dashed #94a3b8;border-radius:5px;background:transparent;color:#475569;font-size:.82rem;font-weight:500;cursor:pointer;width:100%;transition:background .1s,border-color .1s}.btn-add-zone:hover{background:#f1f5f9;border-color:#3b82f6;color:#2563eb}.zone-advanced{font-size:.82rem}.zone-advanced summary{cursor:pointer;color:#64748b;font-weight:500;-webkit-user-select:none;user-select:none;padding:.1rem 0;list-style:none;display:flex;align-items:center;gap:.35rem}.zone-advanced summary:before{content:"▶";font-size:.6rem;color:#94a3b8;transition:transform .15s;display:inline-block}.zone-advanced[open] summary:before{transform:rotate(90deg)}.zone-advanced summary em{font-style:normal;color:#94a3b8;font-weight:400}.building-summary{margin-top:.5rem;display:grid;grid-template-columns:auto 1fr;gap:.2rem .6rem;font-size:.8rem;color:#475569}.building-summary dt{font-weight:500}.building-summary dd{margin:0}.building-summary em{font-style:normal;color:#94a3b8}.stranding-alert{margin-top:.75rem;padding:.65rem .75rem;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px;color:#b91c1c;font-size:.82rem}.stranding-ok{margin-top:.75rem;padding:.65rem .75rem;background:#f0fdf4;border:1px solid #86efac;border-radius:6px;color:#15803d;font-size:.82rem}.help-page{max-width:860px;display:flex;flex-direction:column;gap:0}.help-section{padding:1.5rem 0;border-bottom:1px solid #e2e8f0}.help-section:last-child{border-bottom:none}.help-h2{font-size:1rem;font-weight:700;color:#0f172a;margin:0 0 .75rem}.help-h3{font-size:.85rem;font-weight:700;color:#1e293b;margin:0 0 .6rem}.help-page p{font-size:.875rem;color:#334155;line-height:1.65;margin:0 0 .65rem}.help-page p:last-child{margin-bottom:0}.help-ol,.help-ul{font-size:.875rem;color:#334155;line-height:1.65;margin:0;padding-left:1.4rem;display:flex;flex-direction:column;gap:.4rem}.help-cards{display:flex;flex-direction:column;gap:.75rem}.help-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1rem}.help-dl{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1rem;font-size:.82rem;color:#475569;margin:0}.help-dl dt{font-weight:600;color:#1e293b;white-space:nowrap;padding-top:.05rem}.help-dl dd{margin:0;line-height:1.5}.help-legend-grid{display:flex;flex-direction:column;gap:.65rem}.help-legend-item{display:flex;align-items:flex-start;gap:.75rem;font-size:.875rem;color:#334155;line-height:1.5}.help-swatch{flex-shrink:0;width:1.1rem;height:.25rem;border-radius:2px;margin-top:.55rem}.help-swatch--area{height:.75rem;opacity:.35;margin-top:.3rem;border-radius:3px}.help-swatch--dot{width:.75rem;height:.75rem;border-radius:999px;margin-top:.3rem}.help-page a{color:#2563eb;text-decoration:none}.help-page a:hover{text-decoration:underline}.help-page code{font-family:ui-monospace,Cascadia Code,Fira Mono,monospace;font-size:.82em;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:3px;padding:.1em .35em;color:#0f172a}
