@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700;800;900&display=swap";:root{--bg:#0a0a0f;--bg-2:#111118;--bg-3:#18181f;--surface:#1e1e28;--surface-2:#252530;--surface-glass:#1e1e28bf;--border:#2a2a38;--border-light:#33334a;--border-glow:#f5a62340;--gold:#f5a623;--gold-light:#fbbf47;--gold-dim:#f5a62326;--gold-glow:0 0 30px #f5a62366;--gold-gradient:linear-gradient(135deg, #f5a623, #fbbf47 40%, #fb923c);--accent:#7c6af7;--accent-light:#9d8fff;--accent-dim:#7c6af726;--accent-glow:0 0 30px #7c6af74d;--text:#f0f0f8;--text-2:#a0a0b8;--text-3:#606078;--green:#4ade80;--red:#f87171;--radius:16px;--radius-sm:8px;--radius-lg:24px;--radius-full:999px;--shadow:0 4px 24px #0006;--shadow-lg:0 8px 48px #0009;--shadow-xl:0 16px 64px #000c;--transition:.2s cubic-bezier(.4, 0, .2, 1);--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1);--nav-height:64px;--font-display:"Outfit", -apple-system, sans-serif;--font-body:"Inter", -apple-system, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display)}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea,select{outline:none;font-family:inherit}:root{--sat:env(safe-area-inset-top,0px);--sar:env(safe-area-inset-right,0px);--sab:env(safe-area-inset-bottom,0px);--sal:env(safe-area-inset-left,0px)}body{padding-top:var(--sat);padding-bottom:var(--sab)}*{-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;user-select:text}.loading-screen{background:var(--bg);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-logo{flex-direction:column;align-items:center;gap:24px;display:flex}.logo-text{font-family:var(--font-display);letter-spacing:-3px;background:var(--gold-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:3.5rem;font-weight:900;animation:.6s forwards fadeInUp}.loading-ring{border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}@keyframes glowPulse{0%,to{box-shadow:var(--gold-glow)}50%{box-shadow:0 0 60px #f5a62399}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.navbar{height:var(--nav-height);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;background:#0a0a0fd9;align-items:center;gap:16px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}.navbar-logo{letter-spacing:-1px;background:linear-gradient(135deg, var(--gold), var(--gold-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-right:auto;font-size:1.4rem;font-weight:800}.navbar-links{align-items:center;gap:8px;display:flex}.navbar-link{border-radius:var(--radius-full);color:var(--text-2);transition:all var(--transition);padding:8px 16px;font-size:.875rem;font-weight:500}.navbar-link:hover{color:var(--text);background:var(--surface)}.navbar-link.active{color:var(--gold)}.btn-nav-cta{border-radius:var(--radius-full);background:var(--gold);color:#000;transition:all var(--transition);padding:8px 18px;font-size:.875rem;font-weight:700}.btn-nav-cta:hover{background:var(--gold-light);transform:translateY(-1px)}.btn{border-radius:var(--radius-full);transition:all var(--transition);cursor:pointer;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--gold), #e8971a);color:#000;box-shadow:0 0 24px #f5a6234d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 40px #f5a62380}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--surface-2);transform:translateY(-1px)}.btn-ghost{color:var(--text-2);background:0 0}.btn-ghost:hover{color:var(--text);background:var(--surface)}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-cafe{color:#fbbf47;background:#fbbf4726}.badge-street{color:#94a3b8;background:#94a3b826}.badge-rooftop{color:#818cf8;background:#6366f126}.badge-park{color:#4ade80;background:#4ade8026}.badge-wall-art{color:#f472b6;background:#f472b626}.badge-old-city{color:#fb923c;background:#fb923c26}.badge-modern{color:#38bdf8;background:#38bdf826}.badge-nature{color:#34d399;background:#34d39926}.badge-mall{color:#a78bfa;background:#a78bfa26}.badge-other{background:var(--surface);color:var(--text-2)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--transition);overflow:hidden}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-2);font-size:.875rem;font-weight:500}.form-input{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);width:100%;padding:12px 16px;font-size:.9rem}.form-input:focus{border-color:var(--gold)}.form-input::placeholder{color:var(--text-3)}textarea.form-input{resize:vertical;min-height:100px}select.form-input{appearance:none}.page{min-height:100vh;padding-top:var(--nav-height)}.container{max-width:1200px;margin:0 auto;padding:0 24px}.section{padding:80px 0}.stars{gap:2px;display:flex}.star{color:var(--text-3);font-size:1rem}.star.filled{color:var(--gold)}.map-page{height:calc(100vh - var(--nav-height));margin-top:var(--nav-height);display:flex}.map-container{flex:1;position:relative}.leaflet-container{width:100%;height:100%}.spot-sidebar{background:var(--bg-2);border-right:1px solid var(--border);flex-shrink:0;width:380px;height:100%;overflow-y:auto}@media (width<=768px){.spot-sidebar{display:none}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-up{animation:.6s forwards fadeInUp}.animate-fade{animation:.4s forwards fadeIn}.leaflet-popup-content-wrapper{background:var(--surface)!important;border:1px solid var(--border-light)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;color:var(--text)!important}.leaflet-popup-tip{background:var(--surface)!important}.leaflet-popup-content{margin:0!important}.leaflet-control-zoom{overflow:hidden;border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important}.leaflet-control-zoom a{background:var(--surface)!important;color:var(--text)!important;border-color:var(--border)!important}.leaflet-control-zoom a:hover{background:var(--surface-2)!important}.leaflet-control-attribution{display:none}.desktop-only{align-items:center;gap:8px;display:flex}.nav-avatar{background:linear-gradient(135deg, var(--gold), #fb923c);color:#000;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.8rem;font-weight:800;display:flex}.mobile-menu-btn{color:var(--text);border-radius:var(--radius-sm);transition:background var(--transition);background:0 0;padding:6px;display:none}.mobile-menu-btn:hover{background:var(--surface)}@media (width<=640px){.desktop-only{display:none}.mobile-menu-btn{justify-content:center;align-items:center;display:flex}}.mobile-drawer{top:var(--nav-height);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999;background:#0a0a0ff7;flex-direction:column;padding:24px 20px;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-drawer-inner{flex-direction:column;gap:4px;display:flex}.mobile-nav-link{border-radius:var(--radius);color:var(--text);text-align:left;transition:all var(--transition);cursor:pointer;background:0 0;border:none;align-items:center;gap:14px;width:100%;padding:16px 20px;font-size:1.1rem;font-weight:600;text-decoration:none;display:flex}.mobile-nav-link:hover{background:var(--surface)}.mobile-nav-link.logout{color:var(--red);margin-top:20px}.mobile-nav-link.logout:hover{background:#f871711a}.mobile-nav-cta{background:var(--gold);color:#000;border-radius:var(--radius-full);transition:all var(--transition);justify-content:center;align-items:center;margin-top:16px;padding:16px 24px;font-size:1rem;font-weight:700;text-decoration:none;display:flex}.mobile-nav-cta:hover{background:var(--gold-light)}.more-dropdown{position:relative}.more-trigger{cursor:pointer;align-items:center;gap:4px;display:flex}.more-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:1100;min-width:210px;padding:6px;position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);box-shadow:0 16px 40px #00000080}.more-menu-item{border-radius:var(--radius-sm);color:var(--text-2);transition:all var(--transition);align-items:center;gap:10px;padding:10px 14px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.more-menu-item:hover,.more-menu-item.active{background:var(--bg-3);color:var(--gold)}.mobile-drawer{overflow-y:auto}.mobile-drawer-inner{padding-bottom:40px}
