:root{--bg: #0b1220;--panel: rgba(255, 255, 255, .92);--text: #0f172a;--muted: #64748b;--border: rgba(15, 23, 42, .12);--shadow: 0 10px 30px rgba(2, 6, 23, .18);--radius: 14px}html,body,#root{height:100%;margin:0}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";color:var(--text);background:#0b1220}.appShell{height:100%;display:flex;flex-direction:column}.main{flex:1;min-height:0;background:#0b1220}.mapRoot{height:100%;position:relative}.mapBrand{position:absolute;left:12px;top:12px;z-index:1100;padding:2px 0;font-size:28px;font-weight:800;letter-spacing:.2px;color:#0a1f44;line-height:1}.map{height:100%;width:100%}.banner{position:absolute;left:12px;top:64px;z-index:1000;max-width:min(520px,calc(100% - 24px));background:#fffffff0;border:1px solid rgba(220,38,38,.25);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 14px}.bannerTitle{font-weight:700;margin-bottom:4px}.bannerBody{color:#991b1b;font-size:14px}.pinMarkerIcon{background:transparent;border:none}.pinMarker{transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;gap:6px}.pinMarkerLabel{position:relative;background:#fffffff5;border:1px solid rgba(15,23,42,.14);border-radius:10px;padding:6px 10px;box-shadow:0 10px 20px #0f172a2e;width:max-content;min-width:0;text-align:center}.pinMarkerBadges{position:absolute;top:4px;left:4px;display:inline-flex;gap:4px;z-index:2}.pinMarkerBadge{width:16px;height:16px;border-radius:999px;border:1px solid rgba(15,23,42,.2);background:#fffffff2;display:inline-flex;align-items:center;justify-content:center;font-size:10px;line-height:1}.pinMarkerBadge--bookmark{border-color:#d9770659;background:#fff7edfa}.pinMarkerBadge--owner{border-color:#2563eb59;background:#eff6fffa}.pinMarkerLabel--thumb{width:max-content;min-width:0;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.pinMarkerTitle{font-weight:700;font-size:13px;line-height:1.2}.pinMarkerMeta,.pinMarkerAge{color:var(--muted);font-size:11px;margin-top:2px}.pinMarkerThumb{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid rgba(15,23,42,.12)}.pinMarkerThumbWrap{display:flex;flex-direction:column;align-items:center;gap:4px}.pinMarkerDot{width:10px;height:10px;background:#0f172a;border-radius:999px;border:2px solid #ffffff;box-shadow:0 6px 12px #0f172a33}.popupTitle{font-weight:700;margin-bottom:4px}.popupMeta{color:var(--muted);font-size:13px;margin-bottom:6px}.popupDate{font-size:13px}.mapPopup{width:min(320px,calc(100vw - 72px));max-width:100%}.popupBody{margin:8px 0;color:#0f172a;font-size:14px;line-height:1.4;white-space:pre-wrap}.popupThumb{max-width:100%;width:auto;height:auto;max-height:min(60vh,420px);display:block;border-radius:10px;border:1px solid rgba(15,23,42,.14);margin:8px auto}.popupDetailsList{margin:8px 0;display:grid;gap:6px}.popupDetailsRow{display:grid;grid-template-columns:minmax(88px,40%) minmax(0,1fr);gap:10px;align-items:start}.popupDetailsRow dt{color:#64748b;font-size:12px;font-weight:600;margin:0}.popupDetailsRow dd{color:#0f172a;font-size:13px;margin:0;word-break:break-word}.page{height:100%;overflow:auto;padding:24px;background:#0b1220;color:#e2e8f0}.pageBrand{display:inline-flex;align-items:center;text-decoration:none;color:#fff;font-size:24px;font-weight:800;letter-spacing:.2px;margin-bottom:16px}.pageBrand:hover{text-decoration:underline}.page h1{margin:0 0 12px}.page p{max-width:70ch;line-height:1.6;color:#cbd5e1}.footer{border-top:1px solid rgba(148,163,184,.25);background:#020617e6;color:#cbd5e1}.footerInner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px}.footerLinks{display:flex;gap:14px}.footerLinks a{color:#cbd5e1;text-decoration:none;font-weight:600;font-size:14px}.footerLinks a:hover,.footerLinks a.active{text-decoration:underline}.leaflet-control-attribution{background:#ffffffd9!important}.webAppShell{height:100%;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:radial-gradient(circle at 12% 8%,rgba(56,189,248,.2),transparent 42%),radial-gradient(circle at 80% 0%,rgba(34,197,94,.15),transparent 38%),#071526;color:#e2e8f0}.webAppHeader{padding:14px 16px 10px;border-bottom:1px solid rgba(148,163,184,.22);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#071526c2}.webAppHeaderTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.webAppSignOutBtn{border:1px solid rgba(148,163,184,.3);background:#0f172acc;color:#f8fafc;border-radius:10px;padding:8px 10px;font-weight:600;cursor:pointer}.webAppSignOutBtn:disabled{opacity:.65;cursor:default}.webAppBrand{font-size:22px;font-weight:800;letter-spacing:.2px;color:#f8fafc}.webAppSubtitle{margin:4px 0 0;color:#cbd5e1;font-size:13px}.webHeaderNav{margin-top:10px;display:flex;gap:8px}.webHeaderNavBtn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;text-decoration:none;border:1px solid rgba(148,163,184,.35);color:#dbeafe;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer}.webHeaderNavBtn--active{color:#fff;border-color:#93c5fd;background:#0f172a73}.webAppContent{min-height:0;overflow:auto}.webAppMapTab,.webAppMapTab .mapRoot{height:100%}.webAppMapTab{position:relative}.webDropOverlay{position:absolute;left:0;right:0;top:0;bottom:0;pointer-events:none;display:grid;place-items:center;z-index:1004}.webDropHand{pointer-events:auto;width:48px;height:48px;border-radius:999px;border:0;background:transparent;box-shadow:none;transform:none;display:grid;place-items:center;transition:opacity .14s ease,transform .14s ease}.webDropHand--inactive{opacity:.28}.webDropHand--active{opacity:1}.webDropHandGlyph{font-size:30px;line-height:1;filter:drop-shadow(0 2px 2px rgba(2,6,23,.25))}.webDropHint{position:absolute;transform:translateY(-66px);color:#ea580c;font-size:18px;font-weight:800;letter-spacing:.3px;text-shadow:0 1px 0 rgba(255,255,255,.5)}.webMapActionButtons{position:absolute;right:12px;bottom:18px;z-index:1005;display:grid;gap:10px}.webMapActionButton{width:46px;height:46px;border-radius:50%;border:1px solid rgba(15,23,42,.12);background:#ffffffeb;box-shadow:0 8px 18px #02061738;font-size:20px;line-height:1;cursor:pointer}.webMapActionButton:disabled{opacity:.45;cursor:default}.webDropActionCluster{position:absolute;width:200px;height:200px;border-radius:100px;background:#02061714;transform:translateY(-16px)}.webDropActionBtn{pointer-events:auto;position:absolute;width:52px;height:52px;border-radius:999px;border:0;background:transparent;color:#111827;font-weight:700;box-shadow:none;display:grid;place-items:center}.webDropActionBtn--left{left:6px;top:74px;background:#cdeafe}.webDropActionBtn--top{left:71px;top:6px;background:#d9f7be}.webDropActionBtn--right{right:6px;top:74px;background:#fce1c7}.webPinPickerBackdrop{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:auto;background:#0f172a47;display:grid;place-items:center}.webPinPickerSheet{width:min(320px,calc(100vw - 32px));max-height:calc(100vh - 36px);overflow:auto;border-radius:18px;border:1px solid rgba(148,163,184,.28);background:#0f172af5;box-shadow:0 22px 50px #02061773;padding:12px}.webPinPickerHeader{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.webPinPickerBackBtn,.webPinPickerCloseBtn{border-radius:999px;border:1px solid rgba(148,163,184,.4);background:#0f172ab3;color:#dbeafe;font-size:12px;font-weight:700;padding:6px 11px;cursor:pointer}.webPinPickerGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.webPinPickerTile{border:1px solid rgba(148,163,184,.32);border-radius:12px;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#0f172a;font-size:13px;font-weight:700;padding:14px 10px;min-height:64px;cursor:pointer;text-align:center}.webDropToastStack{position:absolute;left:12px;right:12px;top:12px;z-index:1010;display:grid;gap:8px}.webDropStatus{position:relative;margin:0;border-radius:10px;padding:10px 12px;font-size:13px;animation:webDropToastSlide 2.6s ease forwards}.webDropStatus--success{background:#14532de0;border:1px solid rgba(34,197,94,.5);color:#dcfce7}.webDropStatus--error{background:#450a0ae0;border:1px solid rgba(239,68,68,.5);color:#fee2e2}.webDropStatus--info{background:#1e40afdb;border:1px solid rgba(147,197,253,.55);color:#eff6ff}.webDropStatus--warning{background:#7c2d12e6;border:1px solid rgba(251,146,60,.55);color:#fff7ed}@keyframes webDropToastSlide{0%{opacity:0;transform:translateY(-18px)}10%{opacity:1;transform:translateY(0)}85%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-14px)}}.webDropActionPin{position:absolute;width:44px;height:44px;border-radius:22px;border:1px solid rgba(15,23,42,.08);background:#fff;transform:rotate(45deg);box-shadow:0 6px 10px #0f172a59}.webDropActionPin--picker{background:#cdeafe}.webDropActionPin--camera{background:#d9f7be}.webDropActionPin--poo{background:#fce1c7}.webDropActionPinIcon{position:relative;width:44px;height:44px;display:grid;place-items:center;font-size:24px;line-height:1}.webDropActionPinIcon--picker{transform:translateY(1px);font-size:27px}.webDropActionPinIcon--camera{transform:translateY(-1px)}.webDropActionPinIcon--poo{transform:translate(1px,-3px)}.webDropPooStack{display:grid;place-items:center}.webDropPooArrow{margin-top:-4px;font-size:12px}.webDropActionHighlightRing{position:absolute;width:62px;height:62px;border-radius:31px;border:2px solid #16a34a;box-shadow:0 0 #16a34a73;animation:webDropPulse .85s ease-in-out infinite}@keyframes webDropPulse{0%{opacity:.25;transform:scale(.9);box-shadow:0 0 #16a34a33}50%{opacity:.8;transform:scale(1.15);box-shadow:0 0 0 8px #16a34a0d}to{opacity:.25;transform:scale(.9);box-shadow:0 0 #16a34a33}}.webMapDropPanel{position:absolute;left:12px;right:12px;bottom:12px;z-index:1005;width:auto;max-height:56%;overflow:auto;border:1px solid rgba(148,163,184,.28);border-radius:14px;background:#071526e6;box-shadow:0 16px 36px #02061773;padding:12px;opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .16s ease,transform .16s ease}.webMapDropPanel--open{opacity:1;transform:translateY(0);pointer-events:auto}.webMapDropTitle{color:#f8fafc;font-size:16px;font-weight:700}.webMapDropHint{margin:4px 0 0;color:#cbd5e1;font-size:12px}.webMapDropHint--muted{color:#93c5fd}.webMapDropLabel{display:block;margin-top:10px;margin-bottom:4px;color:#cbd5e1;font-size:12px}.webMapDropInput,.webMapDropTextArea{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid rgba(148,163,184,.34);background:#f1f5f9fa;color:#0f172a;font-size:13px;padding:9px 10px}.webMapDropTextArea{resize:vertical}.webMapDropRow{margin-top:6px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.webMapQuickTypes{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.webMapQuickTypeChip{border:1px solid rgba(148,163,184,.38);background:#f1f5f9f5;color:#0a1f44;border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}.webMapQuickTypeChip--active{background:#0a1f44;color:#fff;border-color:#1d4ed8}.webAppMapTab .banner{top:12px}.webAppPanel{max-width:900px;margin:0 auto;padding:16px}.webAppPanelHeader h2{margin:0;font-size:22px;color:#f8fafc}.webAppPanelHeader p{margin:6px 0 0;color:#cbd5e1}.webAppStatus{margin:14px 0 0;padding:12px;border-radius:12px;border:1px solid rgba(148,163,184,.26);background:#0f172a8c;color:#dbeafe}.webAppStatus--error{border-color:#ef444473;background:#450a0a73;color:#fecaca}.webAppFeed{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:10px}.webAppFeedItem{border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:14px;background:linear-gradient(140deg,#0f172ae6,#1e293bcc)}.webEditCard{display:grid;gap:2px}.webActionRow{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.webUploadBtn{border:1px dashed rgba(148,163,184,.4);border-radius:999px;padding:6px 12px;font-size:12px;color:#dbeafe;cursor:pointer}.webUploadBtn input{display:none}.webPinImages{margin-top:10px;display:grid;gap:10px}.webPinImageItem{border:1px solid rgba(148,163,184,.28);border-radius:12px;padding:8px;background:#0f172a73}.webPinImageThumb{width:100%;max-height:220px;border-radius:10px;object-fit:contain;background:#02061780}.webPrimaryBadge{display:inline-block;border-radius:999px;padding:6px 10px;font-size:12px;color:#052e16;background:#86efac}.webAppFeedItem--alert{background:linear-gradient(140deg,#0284c740,#1e293bd6)}.webAppAlertRowTop{display:flex;align-items:center;justify-content:space-between;gap:10px}.webAppChip{border:1px solid rgba(148,163,184,.35);background:#0f172ab3;color:#e2e8f0;border-radius:999px;padding:6px 10px;font-size:12px;cursor:pointer}.webAppChip:disabled{opacity:.65;cursor:default}.webAppToggle{margin-top:10px;display:inline-flex;align-items:center;gap:8px;color:#dbeafe;font-size:13px}.webAppFeedTitle{font-size:16px;font-weight:700;color:#f8fafc}.webAppFeedMeta{margin-top:4px;color:#93c5fd;font-size:12px}.webAppFeedBody{margin:8px 0 0;color:#cbd5e1;line-height:1.45}.webAppFeedBody .webAppPanelHeader--secondary{margin-top:18px}.webAppFeedTime{margin-top:10px;color:#94a3b8;font-size:12px}.webAppTabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border-top:1px solid rgba(148,163,184,.26);background:#071526f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.webAppTab{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;width:100%;text-decoration:none;color:#cbd5e1;padding:10px 6px 12px;display:grid;justify-items:center;gap:4px;font-size:12px;font-weight:600}.webAppTab--active{color:#fff;background:linear-gradient(180deg,#22c55e33,#0284c71a)}.webAppShell--authOnly{grid-template-rows:1fr}.webAuthScreen{width:min(460px,calc(100vw - 36px));margin:auto;border:1px solid rgba(148,163,184,.28);border-radius:18px;padding:20px;background:#0f172ad1}.webAuthLogo{font-size:28px;font-weight:800;color:#f8fafc;margin-bottom:10px}.webAuthTitle{margin:0;font-size:26px;color:#f8fafc}.webAuthBody{margin:10px 0 0;color:#cbd5e1;line-height:1.5}.webAuthBack{border:none;background:transparent;color:#93c5fd;font-weight:600;padding:0;margin-bottom:10px;cursor:pointer}.webAuthActions{margin-top:18px;display:grid;gap:10px}.webAuthBtn{border-radius:12px;padding:12px 14px;font-weight:700;cursor:pointer}.webAuthBtn:disabled{opacity:.65;cursor:default}.webAuthBtn--primary{border:1px solid #0b254f;background:#0a1f44;color:#fff}.webAuthBtn--secondary{border:1px solid rgba(148,163,184,.38);background:#f1f5f9f5;color:#0a1f44}.webAuthBtn--ghost{border:1px solid rgba(148,163,184,.38);background:transparent;color:#dbeafe}.webAuthToggle{margin:14px 0 0;display:grid;grid-template-columns:1fr 1fr;gap:8px}.webAuthToggleBtn{border-radius:10px;border:1px solid rgba(148,163,184,.34);background:#0f172acc;color:#dbeafe;padding:10px;font-weight:600;cursor:pointer}.webAuthToggleBtn--active{background:#0a1f44;color:#fff;border-color:#1d4ed8}.webAuthFieldLabel{display:block;margin-top:12px;margin-bottom:6px;color:#cbd5e1;font-size:13px}.webAuthInput{width:100%;box-sizing:border-box;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fffffff5;padding:11px 12px;color:#0f172a;font-size:14px}.webAuthHint{margin:10px 0 0;color:#cbd5e1;font-size:12px;line-height:1.45}.webAuthMessage{margin:10px 0 0;color:#86efac;font-size:13px}.webAuthError{margin:10px 0 0;color:#fca5a5;font-size:13px}.webAuthError--inline{margin-top:8px}@media(min-width:900px){.webAppShell{max-width:520px;margin:12px auto;border-radius:24px;overflow:hidden;border:1px solid rgba(148,163,184,.32);box-shadow:0 24px 60px #02061780;height:calc(100% - 24px)}.webMapDropPanel{left:auto;width:360px}}@media(max-width:800px){.webMapDropPanel{max-height:52%}.webDropActionCluster{transform:translateY(-12px) scale(.92)}.webAppMapTab,.webAppMapTab .mapRoot{height:100%}}
