.landing-page{--text-primary: #111;--text-secondary: #555;--text-tertiary: #888;--border: rgb(0 0 0 / 10%);--border-strong: rgb(0 0 0 / 18%);--bg: #fff;--bg-offset: #f8f8f6;--font-mono: "SF Mono", "Fira Code", monospace;--footer-bg: #111;line-height:1.6}.landing-page h1,.landing-page h2,.landing-page h3{text-transform:none;margin-bottom:0}.landing-page a{font-weight:inherit}.wrap{max-width:1120px;margin:0 auto;padding:0 40px}.wrap-narrow{max-width:720px;margin:0 auto;padding:0 40px}.hero{padding:140px 0 120px}.hero-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.hero-text h1{font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:24px}.hero-text p{font-size:1.15rem;color:var(--text-secondary);line-height:1.7;margin-bottom:40px;max-width:420px}.cta-button{display:inline-block;background:var(--text-primary);color:#fff;padding:14px 36px;border-radius:2px;text-decoration:none;font-weight:500;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;transition:all .2s;cursor:pointer;border:none}.cta-button:hover{background:#333;color:#fff}.mockup-frame{border:1px solid var(--border-strong);border-radius:4px;background:var(--bg);overflow:hidden}.mockup-header{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border)}.mockup-header-brand{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.mockup-header-link{font-size:.6rem;color:var(--text-tertiary);font-weight:500}.mockup-streetview{border-bottom:1px solid var(--border)}.mockup-sv-placeholder{display:flex;align-items:center;justify-content:center}.mockup-sv-placeholder svg{width:100%;height:auto}.mockup-flags{display:flex;gap:8px;padding:12px 16px;justify-content:center}.mockup-flag{width:36px;height:36px;border:1px solid var(--border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.mockup-flag--selected{border-color:var(--text-primary);background:#0000000d;box-shadow:0 0 0 2px var(--text-primary)}.landing-page .label{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--text-tertiary);margin-bottom:20px;display:block}.features-section{padding:120px 0}.features-header{margin-bottom:80px;max-width:560px}.features-header h2{font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-bottom:20px}.features-header p{font-size:1.05rem;color:var(--text-secondary);line-height:1.75}.features-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;border-top:1px solid var(--border)}.feature-item{padding:48px 40px 48px 0;border-bottom:1px solid var(--border);position:relative}.feature-item:not(:nth-child(3n)):after{content:"";position:absolute;right:0;top:0;bottom:0;width:1px;background:var(--border)}.feature-item:not(:nth-child(3n)){padding-right:40px}.feature-item:not(:nth-child(3n+1)){padding-left:40px}.feature-icon-line{width:36px;height:36px;margin-bottom:24px}.feature-icon-line svg{width:100%;height:100%;stroke:var(--text-primary);stroke-width:1.5;fill:none}.feature-item h3{font-size:1.05rem;font-weight:600;margin-bottom:10px}.feature-item p{color:var(--text-secondary);font-size:.9rem;line-height:1.7}.concept-section{padding:120px 0;background:var(--bg-offset);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.concept-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:100px;align-items:start}.concept-text h2{font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-bottom:24px}.concept-text>p{font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:48px}.concept-steps{counter-reset:step;list-style:none;padding:0}.concept-steps li{counter-increment:step;display:flex;gap:20px;padding:24px 0;border-top:1px solid var(--border);align-items:baseline}.concept-steps li:before{content:counter(step,decimal-leading-zero);font-size:.75rem;font-weight:600;color:var(--text-tertiary);font-family:var(--font-mono);flex-shrink:0}.concept-step-content h3{font-size:1rem;font-weight:600;margin-bottom:4px}.concept-step-content p{font-size:.88rem;color:var(--text-secondary);line-height:1.65}.concept-illustration{padding-top:20px}.concept-illustration svg{width:100%;height:auto}.cta-section{padding:120px 0;text-align:center}.cta-section h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:700;letter-spacing:-.02em;margin-bottom:16px}.cta-section p{font-size:1.05rem;color:var(--text-secondary);margin-bottom:40px}.landing-footer{background:var(--footer-bg);color:#999;padding:48px 0 36px}.footer-inner{display:flex;justify-content:space-between;align-items:center}.footer-brand{font-size:.75rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff}.footer-links{display:flex;gap:28px}.footer-links a{color:#777;text-decoration:none;font-size:.82rem}.footer-links a:hover{color:#fff}.footer-copyright{font-size:.78rem;color:#555;text-align:center;margin-top:36px;padding-top:24px;border-top:1px solid rgb(255 255 255 / 8%)}@media(max-width:900px){.wrap,.wrap-narrow{padding:0 24px}.hero{padding:80px 0 60px}.hero-layout{grid-template-columns:1fr;gap:48px}.features-row{grid-template-columns:1fr}.feature-item{padding:32px 0!important}.feature-item:after{display:none!important}.concept-layout{grid-template-columns:1fr;gap:48px}.footer-inner{flex-direction:column;gap:20px;text-align:center}.footer-links{flex-wrap:wrap;justify-content:center}}:root{--main-bg-color: #fff;--main-color: #222;--font: -apple-system, blinkmacsystemfont, "Segoe UI", roboto, "Helvetica Neue", arial, sans-serif;--brand: #111;--brand-highlight: #333;--brand-text: #fff;--borderColor: rgb(0 0 0 / 15%);--color-correct: #16a34a;--color-error: #ac1b11}*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,p,ul[class],ol[class],li,figure,figcaption,blockquote,dl,dd{margin:0}body{line-height:1.5;min-height:100vh;scroll-behavior:smooth;text-rendering:optimizespeed}img{display:block;max-width:100%}input,button,textarea,select{font:inherit}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.sr-only{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}html{font-size:16px}html,body{background-color:var(--main-bg-color);color:var(--main-color);display:flex;flex-direction:column;font-family:var(--font);height:100%}h1{font-size:1.2rem;margin-bottom:20px;text-transform:uppercase}a{color:var(--brand);font-weight:700;text-decoration:none}a:focus,a:hover,a:active{text-decoration:underline}button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--brand);border:1px solid var(--brand);color:var(--brand-text);cursor:pointer;min-width:150px;padding:10px 20px;text-align:center;text-transform:uppercase}button[disabled]{opacity:.3}button:focus,button:hover,button:active{background-color:var(--brand-highlight)}.button-secondary{background:#d6d6d6;border-color:#d6d6d6;color:#000;font-weight:700;letter-spacing:.05em;min-height:46px}.button-secondary:hover,.button-secondary:focus{color:#fff}.button-branded{background:#2193b0;border-color:#2193b0;color:#fff}.button-branded:hover,.button-branded:focus{background:#1a7a94;border-color:#1a7a94;color:#fff}.button-link{background:transparent;border:0;color:#000;font-weight:700;margin-right:20px;min-width:70px;padding:0}.button-link:hover,.button-link:focus{background:transparent;border:0}label{display:block;font-size:.75rem;margin-bottom:4px;text-transform:uppercase}.no-margin{margin:0}.site__header{border-bottom:1px solid var(--borderColor);display:flex;justify-content:space-between;align-items:center;padding:18px 40px}.site__brand{font-size:1.2rem;font-weight:700;letter-spacing:0;text-transform:uppercase;margin:0}.site__brand a{color:inherit;text-decoration:none}.site__brand a:hover,.site__brand a:focus,.site__brand a:active{opacity:.6;text-decoration:none}.site__header-right{display:flex;align-items:center;gap:28px}.site__header-nav a{color:var(--main-color);text-decoration:none;font-size:.82rem;font-weight:400}.site__header-github{color:var(--main-color);text-decoration:none;display:flex;align-items:center}.site__header-github:hover{opacity:.5}.site__header-github svg{width:20px;height:20px;fill:currentColor}#app-view{display:flex;flex-direction:column;flex:1 0 auto}#app-view[hidden]{display:none}.site__body{display:flex;flex:1 0 auto;flex-direction:column}.site__footer{border-top:1px solid var(--borderColor);font-size:.85rem;padding:15px 40px}.site__notification{align-items:center;background:#fff;border-bottom:1px solid var(--borderColor);display:flex;font-size:.75rem;justify-content:space-between;min-height:60px;padding:10px 40px;position:sticky;text-transform:uppercase;top:0;z-index:5}.site__toolbar{display:flex;align-items:center;gap:12px}@media(max-width:900px){.site__header{padding:14px 24px}.site__notification{padding:10px 24px}.site__footer{padding:15px 24px}}.form{max-width:450px}.form__entry{margin-bottom:8px}.form__label{margin-bottom:6px}.form__input{border:1px solid var(--borderColor);padding:5px 10px;width:100%}.form__input[aria-invalid=true]{border-color:#ac1b11}.form__error:not(:empty){color:#ac1b11;font-size:.85rem;margin-top:10px}
