*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#080c08;--surface:rgba(16,24,16,.88);--surface2:rgba(20,32,20,.92);--glass:rgba(18,28,18,.82);--border:rgba(80,120,60,.25);--border2:rgba(80,120,60,.4);--green:#3a7a3a;--green2:#5aaa4a;--gold:#d4a039;--gold2:#eabb44;--cream:#e8e0d0;--cream2:#c8bfaa;--orange:#ff6b35;--orange2:#ff8855;--red:#e74c3c;--blue:#3a80b0;--purple:#7a4ab0;--radius:12px;--radius-sm:8px;--shadow:0 8px 32px rgba(0,0,0,.5);--font:"DM Sans",system-ui,sans-serif;--mono:"JetBrains Mono",monospace;--head:"Space Grotesk",system-ui,sans-serif}html,body,#root{height:100%;overflow:hidden;font-family:var(--font);background:var(--bg);color:var(--cream)}#map{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1}.leaflet-container{background:#080c08!important;font-family:var(--font)!important}.leaflet-control-zoom{border:none!important;overflow:hidden;border-radius:var(--radius-sm)!important}.leaflet-control-zoom a{background:var(--surface2)!important;color:var(--gold)!important;border:1px solid var(--border)!important;width:36px!important;height:36px!important;line-height:36px!important;font-size:18px!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:.2s}.leaflet-control-zoom a:hover{background:#3a7a3a59!important;color:var(--gold2)!important}.leaflet-control-zoom-in{border-radius:var(--radius-sm) var(--radius-sm) 0 0!important}.leaflet-control-zoom-out{border-radius:0 0 var(--radius-sm) var(--radius-sm)!important;border-top:none!important}.leaflet-control-attribution{display:none!important}.sel-rect{stroke:var(--orange)!important;stroke-width:2.5!important;fill:#ff6b351a!important;stroke-dasharray:8 4!important}.sel-size-tooltip{background:#142014eb!important;border:1px solid var(--orange)!important;color:var(--orange2)!important;font-family:var(--mono)!important;font-size:.68rem!important;padding:3px 8px!important;border-radius:6px!important;box-shadow:0 2px 8px #0006!important;white-space:nowrap!important;pointer-events:none!important}.sel-size-tooltip:before{border-right-color:var(--orange)!important}#topbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;pointer-events:none}#topbar>*{pointer-events:auto}.brand{display:flex;align-items:center;gap:10px;background:var(--glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:8px 14px;cursor:pointer;transition:.3s}.brand:hover{border-color:var(--border2);background:var(--surface2)}.brand-icon{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--green),var(--green2));display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.brand-text h1{font-family:var(--head);font-size:.85rem;font-weight:600;letter-spacing:.06em;color:var(--cream);line-height:1.1}.brand-text span{font-family:var(--mono);font-size:.58rem;color:var(--cream2);letter-spacing:.03em;opacity:.7}.top-actions{display:flex;gap:8px;align-items:center}.chip{font-family:var(--mono);font-size:.62rem;padding:6px 10px;border-radius:20px;border:1px solid var(--border);background:var(--glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--cream2);letter-spacing:.04em;white-space:nowrap;transition:.2s}.chip.live{color:var(--green2);border-color:#5aaa4a66}.chip.live:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green2);margin-right:6px;animation:pulse 2s ease infinite}.chip.demo{color:var(--orange);border-color:#ff6b3566}.chip.demo:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--orange);margin-right:6px}#credit-chip{cursor:pointer;transition:.3s}#credit-chip:hover{background:var(--surface2);border-color:var(--border2)}.chip.warning{color:var(--gold);border-color:#d4a03980}.chip.empty{color:var(--red);border-color:#e74c3c66}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.icon-btn{width:38px;height:38px;border-radius:var(--radius-sm);background:var(--glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);color:var(--cream);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;transition:.2s}.icon-btn:hover{background:var(--surface2);border-color:var(--border2)}#coords{position:fixed;bottom:16px;left:16px;z-index:50;font-family:var(--mono);font-size:.62rem;color:var(--cream2);opacity:.5;padding:4px 10px;background:var(--glass);border-radius:20px;border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;transition:.3s}#fab{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;align-items:center;gap:8px;padding:14px 22px;border-radius:50px;cursor:pointer;background:linear-gradient(135deg,#2a6a2a,#3a8a3a);border:1px solid rgba(90,170,74,.5);color:#fff;font-family:var(--head);font-size:.85rem;font-weight:600;letter-spacing:.04em;box-shadow:0 4px 24px #2a6a2a66;transition:all .3s ease;-webkit-user-select:none;user-select:none}#fab:hover{transform:translateY(-2px);box-shadow:0 8px 32px #2a6a2a8c;background:linear-gradient(135deg,#3a7a3a,#4a9a4a)}#fab.active{background:linear-gradient(135deg,#8a3010,#b84820);border-color:#ff6b3580;box-shadow:0 4px 24px #b8482066}#fab .fab-icon{font-size:18px;line-height:1}#sel-banner{position:fixed;top:70px;left:50%;transform:translate(-50%);z-index:90;font-family:var(--mono);font-size:.72rem;padding:8px 20px;border-radius:20px;background:#b84820e6;border:1px solid var(--orange);color:#ffd0b0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;opacity:0;transition:all .3s;white-space:nowrap}#sel-banner.show{opacity:1}#prompt-panel{position:fixed;bottom:0;left:0;right:0;z-index:200;transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);pointer-events:none}#prompt-panel.open{transform:translateY(0);pointer-events:auto}.panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;opacity:0;transition:opacity .3s;pointer-events:none;z-index:-1}#prompt-panel.open .panel-backdrop{opacity:1;pointer-events:auto}.panel-body{position:relative;background:var(--surface2);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-top:1px solid var(--border2);border-radius:20px 20px 0 0;padding:20px;max-width:600px;margin:0 auto;width:100%;box-shadow:0 -8px 40px #00000080}.panel-handle{width:36px;height:4px;border-radius:2px;background:#c8bfaa40;margin:0 auto 16px}.panel-sel-info{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}.panel-sel-info .tag{font-family:var(--mono);font-size:.65rem;padding:4px 10px;border-radius:6px;background:#3a7a3a33;border:1px solid rgba(58,122,58,.3);color:var(--green2)}.panel-credit-note{font-family:var(--mono);font-size:.62rem;color:var(--cream2);opacity:.6;margin-bottom:10px}.panel-credit-note.warn{color:var(--gold);opacity:1}.panel-prompt{width:100%;background:#0a100a99;border:1px solid var(--border);color:var(--cream);font-family:var(--font);font-size:.95rem;padding:12px 14px;border-radius:var(--radius-sm);outline:none;resize:none;min-height:80px;line-height:1.5;transition:border-color .2s}.panel-prompt:focus{border-color:var(--green)}.panel-prompt::placeholder{color:#c8bfaa4d;font-style:italic}.panel-actions{display:flex;gap:10px;margin-top:12px;align-items:center}.btn-generate{flex:1;padding:13px 20px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#2a6a2a,#3a8a3a);border:1px solid rgba(90,170,74,.5);color:#fff;font-family:var(--head);font-size:.88rem;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:.25s;position:relative;overflow:hidden}.btn-generate:hover:not(:disabled){background:linear-gradient(135deg,#3a7a3a,#4a9a4a);box-shadow:0 4px 20px #2a6a2a66}.btn-generate:disabled{opacity:.4;cursor:not-allowed}.btn-cancel{padding:13px 18px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border);color:var(--cream2);font-family:var(--font);font-size:.85rem;cursor:pointer;transition:.2s}.btn-cancel:hover{border-color:var(--border2);background:#ffffff0a}#toast{position:fixed;bottom:90px;left:50%;transform:translate(-50%) translateY(20px);z-index:300;font-family:var(--mono);font-size:.72rem;padding:10px 20px;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;max-width:90vw;overflow:hidden}#toast.show{opacity:1;transform:translate(-50%) translateY(0)}#toast.ok{background:#2a6a2ae6;border:1px solid var(--green2);color:#b0e8a0}#toast.err{background:#a01e14e6;border:1px solid var(--red);color:#ffb0a0}#toast.busy{background:#1e3c5ae6;border:1px solid #3a80b0;color:#a0d0f0}.spin{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-right:8px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}#drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400;background:#00000080;opacity:0;pointer-events:none;transition:opacity .3s}#drawer-overlay.open{opacity:1;pointer-events:auto}#drawer{position:fixed;top:0;right:0;bottom:0;z-index:401;width:340px;max-width:85vw;background:var(--surface2);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-left:1px solid var(--border2);transform:translate(100%);transition:transform .35s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;overflow:hidden}#drawer.open{transform:translate(0)}.drawer-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.drawer-header h2{font-family:var(--head);font-size:.95rem;font-weight:600;color:var(--cream)}.drawer-close{width:32px;height:32px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--cream2);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;transition:.2s}.drawer-close:hover{background:#ffffff0d}.drawer-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 20px}.drawer-tab{padding:10px 14px;font-family:var(--mono);font-size:.68rem;color:var(--cream2);cursor:pointer;border-bottom:2px solid transparent;transition:.2s;letter-spacing:.04em}.drawer-tab:hover{color:var(--cream)}.drawer-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.drawer-scroll{flex:1;overflow-y:auto;padding:14px 20px}.drawer-scroll::-webkit-scrollbar{width:3px}.drawer-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.hi{padding:12px 0;border-bottom:1px solid rgba(80,120,60,.15)}.hi:last-child{border-bottom:none}.hi-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.hi-coords{font-family:var(--mono);font-size:.62rem;color:var(--green2)}.hi-mode{font-family:var(--mono);font-size:.58rem;padding:2px 8px;border-radius:10px}.hi-mode.ai{background:#3a7a3a33;color:var(--green2)}.hi-mode.demo{background:#d4a03926;color:var(--gold)}.hi-prompt{font-size:.85rem;color:var(--cream2);line-height:1.4;margin:4px 0}.hi-time{font-family:var(--mono);font-size:.58rem;color:#c8bfaa66}.hi-empty{text-align:center;padding:40px 0;color:#c8bfaa4d;font-style:italic}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600;background:#080c08eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s}.modal-overlay.open{opacity:1;pointer-events:auto}.credits-card{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:32px;max-width:440px;width:100%;box-shadow:var(--shadow);position:relative}.credits-card h2{font-family:var(--head);font-size:1.25rem;font-weight:700;color:var(--cream);margin-bottom:6px;text-align:center}.credits-card .c-sub{font-family:var(--mono);font-size:.65rem;color:var(--gold);letter-spacing:.08em;text-align:center;margin-bottom:24px;opacity:.8}.pack-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:20px}.pack{border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 10px;text-align:center;cursor:pointer;transition:.2s;background:#0a100a66}.pack:hover{border-color:var(--green2);background:#3a7a3a14}.pack.selected{border-color:var(--green2);background:#3a7a3a1f}.pack .pack-credits{font-family:var(--head);font-size:1.2rem;font-weight:700;color:var(--cream)}.pack .pack-label{font-family:var(--mono);font-size:.6rem;color:var(--green2);margin:4px 0}.pack .pack-price{font-family:var(--mono);font-size:.72rem;color:var(--gold);font-weight:600}.pack .pack-per{font-family:var(--mono);font-size:.56rem;color:var(--cream2);opacity:.5;margin-top:2px}.btn-pay{width:100%;padding:14px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#2a6a2a,#3a8a3a);border:1px solid rgba(90,170,74,.5);color:#fff;font-family:var(--head);font-size:.92rem;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:.25s}.btn-pay:hover:not(:disabled){background:linear-gradient(135deg,#3a7a3a,#4a9a4a)}.btn-pay:disabled{opacity:.4;cursor:not-allowed}.btn-modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--cream2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px}.btn-modal-close:hover{background:#ffffff0d}.credits-footer{text-align:center;margin-top:14px;font-family:var(--mono);font-size:.58rem;color:#c8bfaa4d}.user-pill{cursor:pointer;transition:.3s}.user-pill:hover{background:var(--surface2)}.user-pill-anon{color:var(--cream2);opacity:.7}.user-pill-reg{color:var(--gold2)}.auth-card{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:32px;max-width:380px;width:100%;box-shadow:var(--shadow);position:relative;text-align:center}.auth-card h2{font-family:var(--head);font-size:1.1rem;font-weight:700;color:var(--cream);margin-bottom:6px}.auth-card p{font-size:.84rem;color:var(--cream2);line-height:1.5;margin-bottom:20px}.btn-google{width:100%;padding:12px;border-radius:var(--radius-sm);background:#ffffff0f;border:1px solid var(--border2);color:var(--cream);font-family:var(--font);font-size:.88rem;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:10px}.btn-google:hover{background:#ffffff1a}.auth-divider{font-family:var(--mono);font-size:.6rem;color:#c8bfaa4d;margin:10px 0;text-align:center}.auth-input{width:100%;background:#0a100a99;border:1px solid var(--border);color:var(--cream);font-family:var(--font);font-size:.9rem;padding:10px 12px;border-radius:var(--radius-sm);outline:none;transition:border-color .2s;margin-bottom:8px}.auth-input:focus{border-color:var(--green)}.btn-email-auth{width:100%;padding:12px;border-radius:var(--radius-sm);background:linear-gradient(135deg,#2a6a2a,#3a8a3a);border:1px solid rgba(90,170,74,.5);color:#fff;font-family:var(--head);font-size:.88rem;font-weight:600;cursor:pointer;transition:.25s}.btn-email-auth:hover{background:linear-gradient(135deg,#3a7a3a,#4a9a4a)}.auth-toggle{font-family:var(--mono);font-size:.62rem;color:var(--cream2);margin-top:12px;cursor:pointer;opacity:.6}.auth-toggle:hover{opacity:1;color:var(--green2)}.auth-error{font-family:var(--mono);font-size:.65rem;color:var(--red);margin-bottom:8px;text-align:left}.profile-card{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:32px;max-width:400px;width:100%;box-shadow:var(--shadow);position:relative}.profile-card h2{font-family:var(--head);font-size:1.1rem;font-weight:700;color:var(--cream);margin-bottom:16px}.profile-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(200,191,170,.08)}.profile-row:last-child{border-bottom:none}.profile-label{font-family:var(--mono);font-size:.65rem;color:var(--cream2);text-transform:uppercase;letter-spacing:.04em}.profile-value{font-family:var(--mono);font-size:.82rem;color:var(--cream);font-weight:500}.profile-value.gold{color:var(--gold)}.profile-value.green{color:var(--green2)}.profile-actions{margin-top:20px;display:flex;gap:10px}.profile-actions button{flex:1;padding:10px;border-radius:var(--radius-sm);font-family:var(--head);font-size:.8rem;font-weight:600;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--cream2);transition:.2s}.profile-actions button:hover{background:#3a7a3a1a;border-color:var(--green2);color:var(--cream)}.btn-signout{color:var(--red)!important}.btn-signout:hover{border-color:var(--red)!important;background:#e74c3c1a!important}.welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#080c08eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:1;transition:opacity .5s;padding:20px}.welcome-overlay.hidden{opacity:0;pointer-events:none}.welcome-card{background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:40px 36px;max-width:480px;width:100%;text-align:center;box-shadow:var(--shadow);position:relative;overflow:hidden}.welcome-card:before{content:"";position:absolute;top:-60%;left:-20%;width:140%;height:140%;background:radial-gradient(ellipse,rgba(58,122,58,.12),transparent 60%);pointer-events:none}.welcome-icon{width:64px;height:64px;border-radius:16px;margin:0 auto 20px;background:linear-gradient(135deg,var(--green),var(--green2));display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 20px #2a6a2a66}.welcome-card h2{font-family:var(--head);font-size:1.5rem;font-weight:700;color:var(--cream);margin-bottom:6px}.welcome-card .subtitle{font-family:var(--mono);font-size:.68rem;color:var(--gold);letter-spacing:.1em;margin-bottom:20px;opacity:.8}.welcome-card p{font-size:.92rem;color:var(--cream2);line-height:1.6;margin-bottom:16px}.welcome-steps{text-align:left;margin:20px 0;display:flex;flex-direction:column;gap:12px}.welcome-step{display:flex;align-items:flex-start;gap:12px}.step-num{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:#3a7a3a33;border:1px solid rgba(58,122,58,.4);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.68rem;color:var(--green2);font-weight:600}.step-text{font-size:.85rem;color:var(--cream2);line-height:1.4;padding-top:3px}.step-text strong{color:var(--cream);font-weight:500}.btn-start{margin-top:24px;padding:14px 36px;border-radius:50px;cursor:pointer;background:linear-gradient(135deg,#2a6a2a,#3a8a3a);border:1px solid rgba(90,170,74,.5);color:#fff;font-family:var(--head);font-size:.92rem;font-weight:600;letter-spacing:.06em;box-shadow:0 4px 24px #2a6a2a66;transition:.3s}.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 32px #2a6a2a8c}@media(max-width:640px){#topbar{padding:8px 10px}.brand{padding:6px 10px}.chip{font-size:.56rem;padding:4px 8px}#fab{bottom:16px;right:16px;padding:12px 18px;font-size:.78rem}.panel-body{padding:16px;border-radius:16px 16px 0 0}#coords{bottom:12px;left:12px;font-size:.56rem}.welcome-card{padding:28px 24px}.welcome-card h2{font-size:1.2rem}.leaflet-control-zoom{display:none!important}.pack-grid{grid-template-columns:1fr 1fr;gap:8px}}@media(max-width:380px){.top-actions .chip,.brand-text span{display:none}}
