@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap");:root{--bg:#0f1115;--panel:#161a22;--accent:#46c2b6;--accent-2:#f4c95d;--text:#f4f6fb;--muted:#a2acb9}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Space Grotesk,system-ui,sans-serif;background:radial-gradient(1200px 800px at 80% -10%,#1c3b40 0,transparent 60%),radial-gradient(1000px 800px at -10% 20%,#2a1c3b 0,transparent 55%),var(--bg);color:var(--text);min-height:100vh}main{display:grid;grid-template-columns:minmax(280px,380px) 1fr;grid-gap:24px;gap:24px;padding:28px}@media (max-width:900px){main{grid-template-columns:1fr}}.panel{background:var(--panel);border:1px solid hsla(0,0%,100%,.06);border-radius:18px;padding:20px;box-shadow:0 30px 60px rgba(0,0,0,.35)}.title{font-size:28px;font-weight:700;letter-spacing:-.02em}.subtitle{color:var(--muted);margin-top:8px;line-height:1.5}.radius-slider{margin-top:16px;padding:12px 14px;border-radius:12px;background:hsla(0,0%,100%,.04);display:flex;flex-direction:column;gap:10px}.input-toggle{margin-top:16px;grid-template-columns:1fr 1fr}.category-select,.input-toggle{display:grid;grid-gap:8px;gap:8px}.category-select{margin-top:14px}.category-select label{font-size:13px;color:var(--muted)}.select-wrap select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid hsla(0,0%,100%,.1);background:hsla(0,0%,100%,.04);color:var(--text);font-family:inherit}.select-wrap select:focus{outline:none;border-color:rgba(70,194,182,.6)}.toggle{padding:10px 12px;border-radius:12px;border:1px solid hsla(0,0%,100%,.1);background:hsla(0,0%,100%,.04);color:var(--muted);font-weight:600;cursor:pointer}.toggle.active{border-color:rgba(70,194,182,.6);color:var(--text);background:rgba(70,194,182,.15)}.radius-header{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--muted)}.radius-value{color:var(--text);font-weight:600}.radius-slider input[type=range]{width:100%;accent-color:var(--accent)}.radius-options{font-size:11px;color:var(--muted)}.metric,.radius-options{display:flex;justify-content:space-between}.metric{align-items:center;margin-top:16px;padding:12px 14px;border-radius:12px;background:hsla(0,0%,100%,.04)}.metric span{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:6px;background:rgba(70,194,182,.15);color:var(--accent);padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;margin-top:16px}.map-shell{position:relative;height:70vh;min-height:520px;border-radius:20px;overflow:hidden;border:1px solid hsla(0,0%,100%,.08);box-shadow:0 30px 60px rgba(0,0,0,.35)}.maplibregl-ctrl-top-right{margin:12px}.maplibregl-ctrl button{background:rgba(20,24,32,.9);border:1px solid hsla(0,0%,100%,.08)}.maplibregl-ctrl button span{filter:invert(1)}.hint{display:flex;align-items:center;gap:12px;margin-top:24px;padding:16px;background:rgba(70,194,182,.1);border-radius:12px;color:var(--accent);font-weight:500}.hint-icon{font-size:24px}.loading{display:flex;align-items:center;gap:12px;margin-top:24px;padding:16px;background:hsla(0,0%,100%,.04);border-radius:12px;color:var(--muted)}.spinner{width:20px;height:20px;border:2px solid var(--muted);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.error-box{margin-top:24px;padding:16px;background:hsla(0,100%,70%,.15);border-radius:12px;color:#ff6b6b;display:flex;flex-direction:column;gap:10px}.retry-button{align-self:flex-start;padding:8px 12px;border-radius:10px;border:1px solid hsla(0,0%,100%,.2);background:hsla(0,0%,100%,.08);color:var(--text);font-size:12px;font-weight:600;cursor:pointer}.retry-button:hover{border-color:hsla(0,0%,100%,.35)}.total-score{display:flex;align-items:baseline;gap:8px;margin-top:24px;padding:20px;background:linear-gradient(135deg,rgba(70,194,182,.2),rgba(70,194,182,.05));border-radius:16px;border:1px solid rgba(70,194,182,.3)}.score-value{font-size:48px;font-weight:700;color:var(--accent);line-height:1}.score-label{font-size:20px;color:var(--muted)}.pillars{margin-top:20px}.pillar{margin-top:12px;padding:14px;background:hsla(0,0%,100%,.04);border-radius:12px}.pillar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;background:none;border:none;width:100%;cursor:pointer;padding:0;color:inherit;font-family:inherit;font-size:inherit;text-align:left}.pillar-header:hover{opacity:.85}.pillar-name,.pillar-score{font-weight:600;display:flex;align-items:center;gap:6px}.pillar-score{color:var(--accent)}.expand-icon{font-size:10px;color:var(--muted)}.direction-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background:hsla(0,100%,70%,.2);color:#ff6b6b;border-radius:50%;font-size:14px;font-weight:700}.pillar-negative .pillar-score{color:#ff9b6b}.pillar-bar{height:6px;background:hsla(0,0%,100%,.1);border-radius:3px;overflow:hidden}.pillar-fill{height:100%;background:var(--accent);border-radius:3px;transition:width .3s ease}.pillar-fill-negative{background:linear-gradient(90deg,#ff9b6b,#ff6b6b)}.pillar-weight{margin-top:6px;font-size:12px;color:var(--muted)}.pillar-details{margin-top:12px;padding-top:12px;border-top:1px solid hsla(0,0%,100%,.08);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pillar-explanation{color:var(--text);line-height:1.5;font-size:14px;margin-bottom:12px}.pillar-metrics{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.metrics-section{background:rgba(0,0,0,.2);border-radius:8px;padding:10px}.metrics-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);display:block;margin-bottom:8px}.pillar-metrics ul{list-style:none;font-size:12px}.pillar-metrics li{padding:4px 0;color:var(--muted)}.pillar-metrics strong{color:var(--text)}.location-info{margin-top:20px;padding-top:16px;border-top:1px solid hsla(0,0%,100%,.08)}.score-id{font-family:monospace;font-size:12px}.custom-marker{width:24px;height:24px;background:var(--accent);border:3px solid #fff;border-radius:50%;box-shadow:0 4px 12px rgba(0,0,0,.3);cursor:pointer}.map-shell{cursor:crosshair}.landing{display:flex;flex-direction:column;gap:64px;padding:48px 6vw 80px}.hero{display:grid;grid-template-columns:minmax(280px,1fr) minmax(280px,420px);grid-gap:40px;gap:40px;align-items:center}.hero-content h1{font-size:clamp(36px,4vw,64px);line-height:1.05;letter-spacing:-.02em;margin-top:16px}.hero-content h1 span{color:var(--accent)}.hero-content p{margin-top:18px;color:var(--muted);max-width:520px}.hero-tag{display:inline-flex;padding:6px 12px;border-radius:999px;border:1px solid rgba(70,194,182,.3);color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.12em}.hero-actions{display:flex;gap:12px;margin-top:24px}.hero-actions .ghost,.hero-actions .primary{width:auto}.hero-card{background:linear-gradient(150deg,rgba(70,194,182,.25),rgba(22,26,34,.9));border:1px solid rgba(70,194,182,.3);border-radius:20px;padding:24px;display:grid;grid-gap:20px;gap:20px}.hero-score{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--muted)}.hero-score strong{font-size:48px;color:var(--accent)}.hero-list{display:grid;grid-gap:12px;gap:12px}.hero-list div{display:flex;justify-content:space-between;padding:10px 12px;border-radius:12px;background:rgba(0,0,0,.2)}.hero-list span{color:var(--muted);font-size:13px}.hero-list strong{color:var(--text)}.section-title h2{font-size:clamp(24px,3vw,36px)}.section-title p{margin-top:8px;color:var(--muted)}.benefit-grid{grid-template-columns:repeat(2,minmax(220px,1fr));grid-gap:20px}.benefit-grid,.faq-grid{display:grid;gap:20px;margin-top:24px}.faq-grid{grid-template-columns:repeat(2,minmax(240px,1fr));grid-gap:20px}.benefit-card,.faq-item{padding:18px;border-radius:16px;background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.06)}.benefit-card h3,.faq-item h3{margin-bottom:8px}.how-steps{margin-top:24px;display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));grid-gap:20px;gap:20px}.how-step{padding:18px;border-radius:16px;border:1px solid rgba(70,194,182,.3);background:rgba(70,194,182,.08)}.how-step span{font-size:14px;color:var(--accent);letter-spacing:.2em}.how-step h3{margin-top:10px}.footer{display:flex;justify-content:space-between;align-items:center;gap:20px;padding-top:24px;border-top:1px solid hsla(0,0%,100%,.08)}.footer p{color:var(--muted);margin-top:6px}.footer-links{display:flex;gap:16px;font-size:14px}.footer a{color:var(--text);text-decoration:none}.footer a:hover{color:var(--accent)}@media (max-width:900px){.benefit-grid,.faq-grid,.hero,.how-steps{grid-template-columns:1fr}.footer{flex-direction:column;align-items:flex-start}}.share-button{width:100%;margin-top:16px;padding:14px 20px;background:linear-gradient(135deg,var(--accent),#3aa89e);border:none;border-radius:12px;color:var(--bg);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.share-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(70,194,182,.3)}.share-button:active{transform:translateY(0)}.action-buttons{display:flex;gap:12px;margin-top:16px}.action-buttons .compare-button,.action-buttons .share-button{flex:1 1;margin-top:0}.compare-button{padding:14px 20px;background:rgba(244,201,93,.15);border:1px solid rgba(244,201,93,.3);border-radius:12px;color:var(--accent-2);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.compare-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(244,201,93,.2)}.compare-button:disabled{opacity:.4;cursor:not-allowed}.panels-stack{display:flex;flex-direction:column;gap:20px}.compare-panel{background:var(--panel);border:1px solid rgba(244,201,93,.2)}.compare-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.compare-title{font-weight:600;color:var(--accent-2)}.clear-button{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:4px 8px}.clear-button:hover{color:var(--text)}.compare-list{display:flex;flex-direction:column;gap:8px}.compare-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:hsla(0,0%,100%,.04);border-radius:10px;font-size:13px}.compare-index{color:var(--accent-2);font-weight:600;min-width:24px}.compare-coords{flex:1 1;color:var(--muted)}.compare-score{font-weight:600;color:var(--accent)}.remove-button{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.remove-button:hover{color:#ff6b6b}.compare-run-button{width:100%;margin-top:16px;padding:14px 20px;background:linear-gradient(135deg,var(--accent-2),#e0b347);border:none;border-radius:12px;color:var(--bg);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.compare-run-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px rgba(244,201,93,.3)}.compare-run-button:disabled{opacity:.5;cursor:not-allowed}.compare-results{margin-top:20px;border-top:1px solid hsla(0,0%,100%,.08);padding-top:16px}.compare-results-header{padding:8px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.compare-results-header,.compare-results-row{display:grid;grid-template-columns:1fr 80px 100px;grid-gap:12px;gap:12px}.compare-results-row{padding:12px;background:hsla(0,0%,100%,.04);border-radius:10px;margin-top:8px;font-size:13px}.compare-results-row.winner{border:1px solid rgba(244,201,93,.4);background:rgba(244,201,93,.08)}.result-score{font-weight:600;color:var(--accent);display:flex;align-items:center;gap:6px}.winner-badge{font-size:14px}.result-pillar{color:var(--muted)}.address-search{margin-top:16px;display:grid;grid-gap:10px;gap:10px}.address-search label{font-size:13px;color:var(--muted)}.address-input{position:relative}.address-input input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid hsla(0,0%,100%,.08);background:hsla(0,0%,100%,.04);color:var(--text);font-family:inherit}.address-input input:focus{outline:none;border-color:rgba(70,194,182,.5)}.address-loading{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--muted)}.address-results{display:grid;grid-gap:8px;gap:8px}.address-result{text-align:left;padding:10px 12px;border-radius:10px;border:1px solid hsla(0,0%,100%,.08);background:hsla(0,0%,100%,.03);color:var(--text);cursor:pointer;font-size:13px}.address-result:hover{border-color:rgba(70,194,182,.5)}@import url("https://unpkg.com/maplibre-gl@4.7.1/dist/maplibre-gl.css");