@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap";:root{--bg-primary:#050508;--bg-secondary:#0d0d14;--bg-tertiary:#161622;--bg-glass:#0d0d14a6;--bg-glass-light:#16162280;--border-glass:#ffffff0f;--border-glass-hover:#ffffff1f;--text-primary:#f0f0f5;--text-secondary:#8888a0;--text-muted:#55556a;--text-accent:#a78bfa;--accent:#a78bfa;--accent-glow:#a78bfa4d;--accent-gradient:linear-gradient(135deg, #a78bfa, #818cf8, #6366f1);--mood-c1:#a78bfa;--mood-c2:#818cf8;--mood-c3:#6366f1;--mood-glow:#a78bfa66;--header-height:64px;--sidebar-width:380px;--card-radius:16px;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:24px;--font-heading:"Outfit", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow:0 0 30px var(--mood-glow);--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.16, 1, .3, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--glass-blur:blur(24px);--glass-saturate:saturate(200%)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)' opacity='0.03'/%3E%3C/svg%3E");font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.02em;font-weight:600}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.15rem}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.glass{background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass)}.glass-light{background:var(--bg-glass-light);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass)}.btn{border-radius:var(--radius-sm);border:1px solid var(--border-glass);background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--bg-glass-light);border-color:var(--border-glass-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-primary{background:var(--accent-gradient);color:#fff;border:none;font-weight:600}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.btn-sm{padding:6px 14px;font-size:12px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes orbRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes glowPulse{0%,to{box-shadow:0 0 20px var(--mood-glow), 0 0 40px #0000}50%{box-shadow:0 0 30px var(--mood-glow), 0 0 60px var(--mood-glow)}}@keyframes markerBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-glass-light) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-sm);background-size:400% 100%;animation:1.5s infinite shimmer}.stars{color:#fbbf24;gap:2px;font-size:13px;display:inline-flex}.stars .empty{color:var(--text-muted)}.badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.mood-bg-glow{pointer-events:none;z-index:0;opacity:0;transition:opacity .8s;position:fixed;inset:0}.mood-bg-glow.active{opacity:1}.header{z-index:100;border-radius:var(--radius-xl);align-items:center;gap:12px;min-width:420px;max-width:90vw;padding:8px 16px;animation:.4s fadeIn;display:flex;position:fixed;top:12px;left:50%;transform:translate(-50%)}.header-left{align-items:center;display:flex}.logo{border-right:1px solid var(--border-glass);align-items:center;gap:8px;margin-right:4px;padding-right:12px;display:flex}.logo-icon{font-size:22px;animation:3s ease-in-out infinite float}.logo-text{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.header-tabs{border-radius:var(--radius-md);background:#ffffff0a;gap:4px;padding:3px;display:flex}.tab-btn{border-radius:var(--radius-sm);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);background:0 0;border:none;align-items:center;gap:6px;padding:7px 16px;font-size:13px;font-weight:500;display:flex;position:relative}.tab-btn:hover{color:var(--text-primary);background:#ffffff0f}.tab-btn.active{color:var(--text-primary);box-shadow:var(--shadow-sm);background:#ffffff1a}.tab-icon{font-size:14px}.tab-badge{background:var(--accent-gradient);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.tab-badge.meet-badge{background:linear-gradient(135deg,#10b981,#059669)}.tab-badge.scope-badge{background:linear-gradient(135deg,#6366f1,#4f46e5)}.tab-badge.quest-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.tab-badge.budget-badge{background:linear-gradient(135deg,#14b8a6,#0d9488)}.header-right{align-items:center;margin-left:auto;display:flex}.locate-btn{border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex}.locate-btn:hover{color:var(--accent);box-shadow:0 0 15px var(--accent-glow)}.user-avatar-wrapper{position:relative}.user-avatar-btn{background:var(--accent-gradient);color:#fff;width:36px;height:36px;font-family:var(--font-heading);cursor:pointer;transition:all var(--transition-base);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:15px;font-weight:700;display:flex}.user-avatar-btn:hover{box-shadow:0 0 15px var(--accent-glow);transform:scale(1.1)}.profile-dropdown{border-radius:var(--radius-md);z-index:100;width:280px;box-shadow:var(--shadow-lg);padding:16px;animation:.2s both fadeIn;position:absolute;top:calc(100% + 12px);right:0}.dropdown-header{align-items:center;gap:12px;padding-bottom:12px;display:flex}.dropdown-avatar{background:var(--accent-gradient);width:40px;height:40px;font-family:var(--font-heading);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:700;display:flex}.dropdown-email{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:13px;font-weight:600;overflow:hidden}.dropdown-plan{color:var(--text-secondary);margin-top:2px;font-size:11px}.dropdown-divider{background:var(--border-glass);height:1px;margin:8px 0}.dropdown-item{width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:8px;padding:10px 8px;font-size:13px;display:flex}.dropdown-item:hover{background:#ffffff0d}.dropdown-signout{color:#f87171}.mobile-dock,.control-center-overlay{display:none}@media (width<=768px){.header{border-top:1px solid var(--border-glass);width:100%;min-width:100%;max-width:100%;height:calc(var(--header-height) + env(safe-area-inset-bottom,0px));background:#0f172af2;border-radius:0;justify-content:space-between;padding:0;display:flex;top:auto;bottom:0;left:0;transform:none}.logo,.desktop-nav,.header-left,.header-right{display:none}.mobile-dock{width:100%;padding:8px 16px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));justify-content:space-around;align-items:center;display:flex}.dock-btn{color:var(--text-secondary);background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;width:60px;font-size:10px;font-weight:600;display:flex}.dock-btn.active{color:var(--text-primary)}.dock-icon{font-size:20px}.dock-btn-center{background:0 0;border:none;position:relative;top:-15px}.dock-center-inner{color:#fff;background:linear-gradient(135deg,#a78bfa,#6366f1);border-radius:50%;justify-content:center;align-items:center;width:54px;height:54px;display:flex;box-shadow:0 4px 20px #a78bfa66}.grid-icon{font-size:24px}.control-center-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0006;animation:.2s both fadeIn;display:block;position:fixed;inset:0}.control-center-panel{border-top:1px solid var(--border-glass);padding:24px 16px calc(24px + env(safe-area-inset-bottom,0px));background:#0f172af2;border-radius:24px 24px 0 0;animation:.3s cubic-bezier(.34,1.56,.64,1) both slideUp;position:absolute;bottom:0;left:0;right:0}.cc-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding:0 8px;display:flex}.cc-header h3{margin:0;font-size:18px}.cc-close{color:#fff;background:#ffffff1a;border:none;border-radius:16px;justify-content:center;align-items:center;width:32px;height:32px;font-size:20px;display:flex}.cc-grid{grid-template-columns:repeat(4,1fr);gap:16px 8px;display:grid}.cc-grid-item{color:var(--text-secondary);background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;display:flex}.cc-grid-item.active{color:#fff}.cc-grid-item.active .cc-icon-wrapper{background:#ffffff26;border-color:#ffffff4d}.cc-icon-wrapper{border:1px solid var(--border-glass);background:#ffffff0d;border-radius:18px;justify-content:center;align-items:center;width:56px;height:56px;display:flex;position:relative}.cc-icon{font-size:24px}.cc-label{font-size:11px;font-weight:500}.cc-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-4px;box-shadow:0 2px 4px #0000004d}}.marker-user{width:20px;height:20px;position:relative}.marker-user-dot{z-index:2;background:#6366f1;border:2px solid #fff;border-radius:50%;width:12px;height:12px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 10px #6366f199}.marker-user-ring{border:2px solid #6366f14d;border-radius:50%;width:30px;height:30px;animation:2s ease-in-out infinite glowPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.marker-custom{cursor:pointer;transition:transform var(--transition-base);position:relative}.marker-custom:hover{transform:scale(1.2)}.marker-custom.selected{z-index:100;transform:scale(1.3)}.marker-dot{background:var(--mood-c1);width:14px;height:14px;box-shadow:0 0 12px var(--mood-glow);transition:all var(--transition-base);border:2px solid #ffffffe6;border-radius:50%;display:block}.marker-custom.selected .marker-dot{width:18px;height:18px;box-shadow:0 0 20px var(--mood-glow), 0 0 40px var(--mood-glow);animation:1.5s ease-in-out infinite glowPulse}.marker-custom.in-itinerary .marker-dot{background:var(--accent);box-shadow:0 0 15px var(--accent-glow)}.marker-number{background:var(--accent-gradient);color:#fff;width:26px;height:26px;font-family:var(--font-heading);box-shadow:0 2px 8px #0006, 0 0 15px var(--accent-glow);border:2px solid #ffffffe6;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.marker-tooltip{white-space:nowrap;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-glass);color:var(--text-primary);box-shadow:var(--shadow-md);pointer-events:none;border-radius:6px;padding:5px 10px;font-size:12px;font-weight:500;animation:.2s fadeIn;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.marker-tooltip:after{content:"";border:5px solid #0000;border-top-color:var(--bg-glass);position:absolute;top:100%;left:50%;transform:translate(-50%)}.map-view-controls{border-radius:var(--radius-md);flex-direction:column;gap:4px;margin:16px;padding:4px;display:flex;box-shadow:0 4px 12px #00000080;background:#111827cc!important}.mode-btn{width:44px;height:44px;font-family:var(--font-heading);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:13px;font-weight:700;transition:all .2s;display:flex}.mode-btn:hover{color:var(--text-primary);background:#ffffff1a}.mode-btn.active{background:var(--gradient-primary);color:#fff;box-shadow:0 0 10px #a78bfa80}.map-container{z-index:0;position:fixed;inset:0}.map-container>div{width:100%!important;height:100%!important}.map-mood-overlay{pointer-events:none;z-index:1;opacity:.6;transition:opacity .6s;position:absolute;inset:0}.mood-selector{padding:16px;animation:.3s fadeIn}.mood-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:14px;font-weight:600}.mood-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.mood-orb{border:1px solid var(--border-glass);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);background:#ffffff08;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;display:flex;position:relative;overflow:hidden}.mood-orb .orb-bg{background:var(--orb-gradient);opacity:0;border-radius:inherit;transition:opacity .4s;position:absolute;inset:0}.mood-orb:hover{border-color:var(--border-glass-hover);transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.mood-orb:hover .orb-bg{opacity:.1}.mood-orb.active{box-shadow:0 0 20px var(--orb-glow), 0 4px 20px #0006;border-color:#0000;transform:translateY(-2px)scale(1.03)}.mood-orb.active .orb-bg{opacity:.2}.mood-orb.active:before{content:"";border-radius:inherit;background:var(--orb-gradient);-webkit-mask-composite:xor;padding:1px;position:absolute;inset:-1px;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;mask-position:0 0,0 0;-webkit-mask-size:auto,auto;mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.orb-emoji{z-index:1;transition:transform var(--transition-spring);font-size:26px;position:relative}.mood-orb:hover .orb-emoji{transform:scale(1.15)}.mood-orb.active .orb-emoji{animation:2s ease-in-out infinite float;transform:scale(1.2)}.orb-label{color:var(--text-secondary);z-index:1;transition:color var(--transition-base);letter-spacing:.02em;font-size:11px;font-weight:600;position:relative}.mood-orb.active .orb-label{color:var(--text-primary)}.mood-loading{flex-direction:column;align-items:center;gap:10px;padding:20px 0;animation:.3s fadeIn;display:flex}.mood-loading p{color:var(--text-secondary);font-size:12px}.loading-dots{gap:6px;display:flex}.loading-dots span{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}.mood-results-count{justify-content:center;padding-top:14px;animation:.4s fadeIn;display:flex}.results-badge{color:#fff;border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;display:inline-flex}@media (width<=600px){.mood-grid{grid-template-columns:repeat(6,1fr);gap:6px}.mood-orb{padding:10px 4px}.orb-emoji{font-size:22px}.orb-label{font-size:9px}.mood-title{display:none}.mood-selector{padding:10px 12px}}.search-bar{border-radius:var(--radius-md);transition:all var(--transition-base);align-items:center;gap:8px;margin:12px 16px;padding:10px 14px;display:flex}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-icon{flex-shrink:0;font-size:14px}.search-input{color:var(--text-primary);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;font-size:13px}.search-input::placeholder{color:var(--text-muted)}.pac-container{background:var(--bg-secondary)!important;border:1px solid var(--border-glass)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important;font-family:var(--font-body)!important;z-index:10000!important;margin-top:4px!important}.pac-item{cursor:pointer;transition:background .15s;color:var(--text-primary)!important;border-top-color:var(--border-glass)!important;padding:8px 12px!important;font-size:13px!important}.pac-item:hover{background:#ffffff0f!important}.pac-item-query{color:var(--text-primary)!important;font-weight:500!important}.pac-matched{color:var(--accent)!important;font-weight:600!important}.pac-icon{filter:invert(.7)!important}.place-card{border-radius:var(--card-radius);background:var(--bg-glass);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-glass);cursor:pointer;transition:all var(--transition-base);flex:0 0 220px;animation:.4s both fadeInScale;overflow:hidden}.place-card:hover{border-color:var(--border-glass-hover);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.place-card.selected{border-color:var(--mood-c1);box-shadow:0 0 25px var(--mood-glow), var(--shadow-lg)}.place-card-image{width:100%;height:130px;position:relative;overflow:hidden}.place-card-image img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.place-card:hover .place-card-image img{transform:scale(1.05)}.place-card-no-image{background:var(--bg-tertiary);justify-content:center;align-items:center;width:100%;height:100%;font-size:32px;display:flex}.place-card-image-overlay{background:linear-gradient(to top, var(--bg-secondary), transparent);pointer-events:none;height:50%;position:absolute;bottom:0;left:0;right:0}.place-card-type-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em;background:#0009;border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600;position:absolute;top:8px;left:8px}.place-card-body{flex-direction:column;gap:6px;padding:12px;display:flex}.place-card-name{font-family:var(--font-heading);color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.place-card-meta{align-items:center;gap:6px;display:flex}.place-card-rating{color:#fbbf24;font-size:13px;font-weight:700}.place-card-count{color:var(--text-muted);font-size:11px}.place-card-info{color:var(--text-secondary);align-items:center;gap:10px;font-size:12px;display:flex}.place-card-distance{align-items:center;gap:3px;display:flex}.place-card-price{color:#4ade80;font-weight:600}.place-card-add{width:100%;margin-top:4px;font-size:12px}.place-card-add.added{color:#4ade80;cursor:default;background:#4ade8026;border-color:#4ade804d}.place-card-add.added:hover{box-shadow:none;transform:none}.places-carousel{z-index:50;pointer-events:none;padding:0 0 20px;animation:.4s slideUp;position:fixed;bottom:0;left:0;right:0}.carousel-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;pointer-events:auto;scrollbar-width:none;gap:12px;padding:12px 20px;scroll-padding:20px;display:flex;overflow:auto hidden}.carousel-scroll::-webkit-scrollbar{display:none}.carousel-scroll>*{scroll-snap-align:start}.places-carousel:before,.places-carousel:after{content:"";z-index:2;pointer-events:none;width:40px;position:absolute;top:0;bottom:0}.places-carousel:before{background:linear-gradient(to right, var(--bg-primary), transparent);left:0}.places-carousel:after{background:linear-gradient(to left, var(--bg-primary), transparent);right:0}@media (width>=901px){.places-carousel{left:var(--sidebar-width)}}@media (width<=600px){.carousel-scroll{gap:8px;padding:8px 12px}.places-carousel{padding-bottom:12px}}.detail-backdrop{z-index:200;background:#00000080;animation:.2s fadeIn;position:fixed;inset:0}.detail-sheet{z-index:201;border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:500px;max-height:80vh;animation:.35s cubic-bezier(.16,1,.3,1) slideUp;position:fixed;bottom:0;left:50%;overflow-y:auto;transform:translate(-50%)}.detail-header{z-index:2;background:inherit;justify-content:center;align-items:center;padding:12px 16px 8px;display:flex;position:sticky;top:0}.detail-drag-handle{background:#fff3;border-radius:2px;width:36px;height:4px}.detail-close{width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:12px;right:16px}.detail-close:hover{color:var(--text-primary);background:#fff3}.detail-photos{overflow:hidden}.detail-photos-scroll{scroll-snap-type:x mandatory;scrollbar-width:none;gap:4px;display:flex;overflow-x:auto}.detail-photos-scroll::-webkit-scrollbar{display:none}.detail-photos-scroll img{object-fit:cover;scroll-snap-align:start;flex:0 0 100%;width:100%;height:200px}.detail-content{flex-direction:column;gap:10px;padding:16px 20px 24px;display:flex}.detail-name{font-size:22px;font-weight:700;line-height:1.2}.detail-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.detail-rating{color:#fbbf24;font-size:15px;font-weight:700}.detail-count{color:var(--text-muted);font-size:13px}.detail-price{color:#4ade80;font-size:14px;font-weight:600}.detail-type-badge{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:#ffffff14;border-radius:6px;align-self:flex-start;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.detail-address{color:var(--text-secondary);font-size:13px;line-height:1.4}.detail-summary{color:var(--text-secondary);border-top:1px solid var(--border-glass);padding:8px 0;font-size:14px;line-height:1.6}.detail-actions{gap:8px;padding-top:8px;display:flex}.detail-actions .btn{flex:1;justify-content:center;text-decoration:none}.detail-actions .added{color:#4ade80;cursor:default;background:#4ade8026;border:1px solid #4ade804d}@media (width>=901px){.detail-sheet{left:calc(var(--sidebar-width) + 50%);transform:translateX(calc(-50% - var(--sidebar-width) / 2))}}.itinerary-timeline{flex-direction:column;flex:1;gap:0;padding-bottom:20px;display:flex;overflow-y:auto}.timeline-stop{gap:12px;animation:.3s both fadeIn;display:flex}.stop-line{flex-direction:column;flex-shrink:0;align-items:center;width:32px;display:flex}.stop-number{background:var(--accent-gradient);color:#fff;width:28px;height:28px;font-family:var(--font-heading);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.stop-travel{flex-direction:column;flex:1;align-items:center;gap:2px;padding:4px 0;display:flex}.travel-line{background:repeating-linear-gradient(to bottom, var(--border-glass-hover) 0, var(--border-glass-hover) 4px, transparent 4px, transparent 8px);flex:1;width:2px;min-height:16px}.travel-time{color:var(--text-muted);white-space:nowrap;padding:2px 0;font-size:10px}.stop-card{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);flex:1;align-items:center;gap:10px;margin-bottom:8px;padding:10px;display:flex;position:relative}.stop-card:hover{border-color:var(--border-glass-hover);box-shadow:var(--shadow-sm)}.stop-drag{cursor:grab;color:var(--text-muted);-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);padding:2px;font-size:14px;line-height:1}.stop-drag:hover{color:var(--text-secondary)}.stop-drag:active{cursor:grabbing}.stop-info{flex:1;min-width:0}.stop-time{color:var(--accent);font-size:11px;font-weight:600;font-family:var(--font-heading)}.stop-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;line-height:1.3;overflow:hidden}.stop-meta{gap:8px;margin-top:2px;display:flex}.stop-type,.stop-duration{color:var(--text-muted);font-size:11px}.stop-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:44px;height:44px}.stop-remove{width:20px;height:20px;color:var(--text-muted);cursor:pointer;opacity:0;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:10px;display:flex;position:absolute;top:4px;right:4px}.stop-card:hover .stop-remove{opacity:1}.stop-remove:hover{color:#ef4444;background:#ef444433}.dayforge-panel{flex-direction:column;height:100%;padding:16px;animation:.3s fadeIn;display:flex}.dayforge-header{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.dayforge-title{margin-bottom:4px;font-size:16px;font-weight:700}.dayforge-duration{color:var(--text-secondary);font-size:12px}.dayforge-actions{gap:6px;margin-bottom:14px;display:flex}.dayforge-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:30px 16px;display:flex}.empty-icon{font-size:40px;animation:3s ease-in-out infinite float}.dayforge-empty h4{color:var(--text-primary);font-size:16px}.dayforge-empty p{color:var(--text-secondary);max-width:260px;font-size:13px;line-height:1.5}.empty-hint{border-radius:var(--radius-sm);background:#a78bfa1a;border:1px solid #a78bfa33;margin-top:8px;padding:10px 14px;font-size:12px!important}.empty-hint strong{color:var(--accent)}.meetpoint-panel{flex-direction:column;gap:16px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.meetpoint-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:8px}.meetpoint-title{margin-bottom:4px;font-size:18px;font-weight:700}.meetpoint-subtitle{color:var(--text-secondary);font-size:12px}.meetpoint-add-section{flex-direction:column;gap:8px;display:flex}.meetpoint-input-group{flex-direction:column;gap:6px;display:flex}.meetpoint-name-input,.meetpoint-location-input{border-radius:var(--radius-sm);border:1px solid var(--border-glass);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-fast);background:#ffffff0a;outline:none;padding:9px 12px;font-size:13px}.meetpoint-name-input:focus,.meetpoint-location-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.meetpoint-name-input::placeholder,.meetpoint-location-input::placeholder{color:var(--text-muted)}.meetpoint-add-buttons{gap:6px;display:flex}.meetpoint-add-buttons .btn{flex:1}.meetpoint-friends{flex-direction:column;gap:6px;display:flex}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px;font-size:11px;font-weight:700}.friend-item{border-radius:var(--radius-sm);border:1px solid var(--border-glass);background:#ffffff08;align-items:center;gap:10px;padding:8px 10px;animation:.3s fadeInScale;display:flex}.friend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;box-shadow:0 0 8px}.friend-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.friend-name{color:var(--text-primary);font-size:13px;font-weight:600}.friend-address{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.friend-remove{width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:11px;display:flex}.friend-remove:hover{color:#ef4444;background:#ef444433}.meetpoint-find-btn{width:100%;padding:12px;font-size:14px;font-weight:700;animation:.3s fadeIn}.meetpoint-loading{flex-direction:column;align-items:center;gap:10px;padding:20px 0;animation:.3s fadeIn;display:flex}.meetpoint-loading p{color:var(--text-secondary);font-size:12px}.meetpoint-results{flex-direction:column;gap:6px;display:flex}.meet-place-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;align-items:center;gap:10px;padding:8px;animation:.3s both fadeIn;display:flex}.meet-place-item:hover{border-color:var(--border-glass);background:#ffffff0d}.meet-place-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:48px;height:48px}.meet-place-no-img{background:var(--bg-tertiary);justify-content:center;align-items:center;font-size:20px;display:flex}.meet-place-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.meet-place-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.meet-place-meta{color:var(--text-muted);gap:8px;font-size:11px;display:flex}.meet-place-rating{color:#fbbf24;font-weight:600}.meet-place-type{text-transform:capitalize}.meet-place-distances{flex-wrap:wrap;gap:4px;margin-top:2px;display:flex}.dist-badge{border-radius:4px;padding:1px 6px;font-size:10px;font-weight:500}.dist-mid{color:#818cf8;background:#6366f126}.dist-max{color:#fbbf24;background:#f59e0b26}.meetpoint-clear-btn{align-self:center;margin-top:auto}.scope-panel{flex-direction:column;gap:16px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.scope-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:8px}.scope-title{margin-bottom:4px;font-size:18px;font-weight:700}.scope-subtitle{color:var(--text-secondary);font-size:12px}.scope-search{flex-direction:column;gap:8px;display:flex}.scope-input{border-radius:var(--radius-sm);border:1px solid var(--border-glass);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-fast);background:#ffffff0a;outline:none;padding:10px 12px;font-size:13px}.scope-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.scope-input::placeholder{color:var(--text-muted)}.scope-search-btns{gap:6px;display:flex}.scope-search-btns .btn{flex:1}.scope-loading{flex-direction:column;align-items:center;gap:10px;padding:30px 0;animation:.3s fadeIn;display:flex}.scope-loading p{color:var(--text-secondary);text-align:center;font-size:12px}.scope-report{flex-direction:column;gap:16px;animation:.4s fadeIn;display:flex}.scope-overall{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:#ffffff0a;align-items:center;gap:14px;padding:14px;display:flex}.score-ring{flex-shrink:0;position:relative}.score-value{font-family:var(--font-heading);justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex;position:absolute;inset:0}.scope-overall-info{flex:1;min-width:0}.scope-area-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:14px;font-weight:700;overflow:hidden}.scope-stats{color:var(--text-muted);margin-bottom:6px;font-size:11px}.scope-grade{text-transform:uppercase;letter-spacing:.05em;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.grade-a{color:#10b981;background:#10b98126}.grade-b{color:#f59e0b;background:#f59e0b26}.grade-c{color:#ef4444;background:#ef444426}.scope-radar-wrap{justify-content:center;padding:8px 0;display:flex}.radar-canvas{image-rendering:auto}.scope-categories{flex-direction:column;gap:4px;display:flex}.scope-cat{border-radius:var(--radius-sm);transition:all var(--transition-fast);overflow:hidden}.scope-cat-header{cursor:pointer;transition:background var(--transition-fast);border-radius:var(--radius-sm);align-items:center;gap:8px;padding:8px 10px;display:flex}.scope-cat-header:hover{background:#ffffff0a}.scope-cat-emoji{flex-shrink:0;font-size:16px}.scope-cat-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.scope-cat-label{color:var(--text-primary);font-size:12px;font-weight:600}.scope-cat-meta{color:var(--text-muted);font-size:10px}.scope-cat-bar-wrap{background:#ffffff0f;border-radius:3px;flex-shrink:0;width:50px;height:6px;overflow:hidden}.scope-cat-bar{border-radius:3px;height:100%;transition:width .8s}.scope-cat-score{font-family:var(--font-heading);text-align:right;flex-shrink:0;width:28px;font-size:13px;font-weight:700}.scope-cat-chevron{color:var(--text-muted);flex-shrink:0;font-size:10px}.scope-cat-places{flex-direction:column;gap:4px;padding:4px 8px 8px 34px;animation:.2s fadeIn;display:flex}.scope-place-item{cursor:pointer;transition:background var(--transition-fast);border-radius:6px;align-items:center;gap:8px;padding:6px;display:flex}.scope-place-item:hover{background:#ffffff0a}.scope-place-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:32px;height:32px}.scope-no-img{background:var(--bg-tertiary);justify-content:center;align-items:center;font-size:14px;display:flex}.scope-place-info{flex:1;min-width:0}.scope-place-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;display:block;overflow:hidden}.scope-place-rating{color:#fbbf24;font-size:10px}.scope-clear{align-self:center}.quest-panel{flex-direction:column;gap:16px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.quest-panel-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:8px}.quest-panel-title{margin-bottom:4px;font-size:18px;font-weight:700}.quest-panel-subtitle{color:var(--text-secondary);font-size:12px}.xp-bar-section{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:#ffffff0a;padding:12px}.xp-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.xp-level{font-family:var(--font-heading);color:#fbbf24;font-size:14px;font-weight:700}.xp-amount{color:var(--text-secondary);font-size:12px;font-weight:600}.xp-bar-track{background:#ffffff0f;border-radius:4px;height:8px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg,#fbbf24,#f59e0b);border-radius:4px;height:100%;transition:width .6s}.xp-next{color:var(--text-muted);margin-top:4px;font-size:10px;display:block}.quest-stats{gap:8px;display:flex}.stat-chip{border-radius:var(--radius-sm);border:1px solid var(--border-glass);background:#ffffff08;flex-direction:column;flex:1;align-items:center;gap:2px;padding:10px 6px;display:flex}.stat-value{font-family:var(--font-heading);color:var(--text-primary);font-size:18px;font-weight:800}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.quest-list{flex-direction:column;gap:8px;display:flex}.quest-card{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);border:1px solid var(--border-glass);animation:.3s both fadeIn;position:relative;overflow:hidden}.quest-card:hover{border-color:var(--border-glass-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.quest-card.active{border-color:#a78bfa4d;box-shadow:0 0 20px #a78bfa1a}.quest-card.completed{opacity:.7}.quest-card-gradient{height:3px;position:absolute;top:0;left:0;right:0}.quest-card-content{padding:12px}.quest-card-top{align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.quest-emoji{flex-shrink:0;font-size:28px}.quest-info{flex:1;min-width:0}.quest-title{margin-bottom:2px;font-size:14px;font-weight:700}.quest-desc{color:var(--text-secondary);font-size:11px;line-height:1.4}.quest-xp{color:#fbbf24;white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:700}.quest-progress-bar{background:#ffffff0f;border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.quest-progress-bar.large{border-radius:3px;height:6px;margin-top:8px}.quest-progress-fill{border-radius:inherit;height:100%;transition:width .8s}.quest-card-bottom{justify-content:space-between;align-items:center;display:flex}.quest-status{color:var(--text-muted);font-size:11px}.quest-action-btn{padding:4px 12px;font-size:11px}.quest-back{align-self:flex-start;font-size:12px}.quest-detail-header{text-align:center;border-radius:var(--radius-md);border:1px solid var(--border-glass);padding:20px 16px}.quest-detail-emoji{margin-bottom:8px;font-size:40px;display:block}.quest-detail-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.quest-detail-header p{color:var(--text-secondary);font-size:12px}.quest-detail-progress{margin-top:12px}.quest-detail-progress>span{color:var(--text-primary);font-size:12px;font-weight:600}.quest-objectives{flex-direction:column;gap:8px;display:flex}.objective-item{border-radius:var(--radius-sm);border:1px solid var(--border-glass);transition:all var(--transition-fast);background:#ffffff08;padding:10px}.objective-item.done{background:#4ade800d;border-color:#4ade8033}.objective-header{align-items:center;gap:8px;display:flex}.objective-check{flex-shrink:0;font-size:14px}.objective-label{flex:1;font-size:13px;font-weight:500}.objective-count{color:var(--text-muted);font-size:11px;font-weight:600;font-family:var(--font-heading)}.objective-places{border-top:1px solid var(--border-glass);flex-direction:column;gap:4px;margin-top:8px;padding-top:8px;display:flex}.obj-place{cursor:pointer;transition:background var(--transition-fast);border-radius:6px;align-items:center;gap:8px;padding:6px;display:flex}.obj-place:hover{background:#ffffff0a}.obj-place-thumb{object-fit:cover;border-radius:6px;flex-shrink:0;width:36px;height:36px}.obj-no-img{background:var(--bg-tertiary);justify-content:center;align-items:center;font-size:14px;display:flex}.obj-place-info{flex:1;min-width:0}.obj-place-name{white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;display:block;overflow:hidden}.obj-place-rating{color:#fbbf24;font-size:10px}.obj-checkin{white-space:nowrap;flex-shrink:0;padding:4px 8px;font-size:10px}.obj-checkin.checked{color:#4ade80;cursor:default;background:#4ade8026;border-color:#4ade804d}.budget-panel{flex-direction:column;gap:20px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.budget-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.budget-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.budget-header p{color:var(--text-secondary);font-size:12px}.budget-overview{border:1px solid var(--border-glass);border-radius:var(--radius-lg);background:#ffffff08;align-items:center;gap:20px;padding:16px;display:flex}.budget-chart{flex-shrink:0;width:90px;height:90px}.circular-chart{max-width:80%;max-height:250px;margin:0 auto;display:block}.circular-bg{fill:none;stroke:#ffffff14;stroke-width:8px}.circular-path{fill:none;stroke-width:8px;stroke-linecap:round;transform-origin:50%;transition:stroke-dashoffset 1s ease-out,stroke .3s;transform:rotate(-90deg)}.chart-text{font-family:var(--font-heading);font-size:24px;font-weight:800;transform:translateY(2px)}.budget-stats{flex-direction:column;flex:1;gap:12px;display:flex}.stat-row{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--text-secondary);font-size:12px}.stat-val{font-family:var(--font-heading);font-size:14px;font-weight:700}.stat-val.spent{font-size:18px}.stat-val.limit{cursor:pointer;color:var(--text-muted);-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.stat-val.remaining{color:#4ade80}.stat-val.remaining.over{color:#ef4444}.limit-edit .input-sm{text-align:right;width:80px;padding:4px 8px;font-size:14px}.budget-section{flex-direction:column;gap:12px;display:flex}.section-head{border-bottom:1px solid var(--border-glass);justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.section-head h4{font-size:14px;font-weight:600}.section-total{font-family:var(--font-heading);color:var(--text-secondary);font-size:14px;font-weight:700}.empty-msg{color:var(--text-muted);text-align:center;padding:20px 0;font-size:12px}.expense-list{flex-direction:column;gap:8px;list-style:none;display:flex}.expense-item{border-radius:var(--radius-sm);background:#ffffff05;border:1px solid #0000;align-items:center;gap:12px;padding:10px 12px;transition:background .2s;display:flex}.expense-item:hover{background:#ffffff0a}.expense-info{flex-direction:column;flex:1;min-width:0;display:flex}.expense-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.expense-type{color:var(--text-muted);text-transform:capitalize;font-size:11px}.expense-amount{font-family:var(--font-heading);color:var(--text-primary);font-size:14px;font-weight:600}.btn-remove{opacity:0;width:24px;height:24px;font-size:12px;transition:opacity .2s}.expense-item.manual:hover .btn-remove{opacity:1}.add-expense-form{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:#0003;flex-direction:column;gap:10px;padding:12px;display:flex}.form-row{gap:8px;display:flex}.form-row>input,.form-row>select{flex:1;min-width:0}.form-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.form-actions .btn{flex:1}.warp-panel{flex-direction:column;gap:20px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.warp-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.warp-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.warp-header p{color:var(--text-secondary);font-size:12px}.era-list{flex-direction:column;gap:16px;display:flex}.era-card{border-radius:var(--radius-lg);border:1px solid var(--border-glass);cursor:pointer;transition:all var(--transition-base);background:#0003;position:relative;overflow:hidden}.era-card:hover{border-color:var(--border-glass-hover);transform:translateY(-2px)}.era-card.active{border-color:#a78bfa99;box-shadow:0 0 20px #a78bfa26}.era-preview{width:100%;height:80px;position:relative;overflow:hidden}.era-preview-map{background-color:#1f2937;background-image:linear-gradient(45deg,#111827 25%,#0000 25% 75%,#111827 75%,#111827),linear-gradient(45deg,#111827 25%,#0000 25% 75%,#111827 75%,#111827),none;background-position:0 0,10px 10px;background-repeat:repeat,repeat,repeat;background-size:20px 20px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;position:absolute;inset:0}.era-preview-overlay{pointer-events:none;position:absolute;inset:0}.era-info{background:#ffffff05;align-items:center;gap:12px;padding:12px 16px;display:flex}.era-emoji{font-size:24px}.era-text{flex:1}.era-text h4{margin-bottom:2px;font-size:14px;font-weight:600}.era-text p{color:var(--text-muted);font-size:11px}.era-radio{border:2px solid var(--border-glass-hover);border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.era-card.active .era-radio{border-color:#a78bfa}.radio-inner{background:#a78bfa;border-radius:50%;width:10px;height:10px;animation:.2s zoomIn}.era-active-notice{border-radius:var(--radius-md);border-left:3px solid #a78bfa;padding:12px}.era-active-notice p{color:var(--text-secondary);font-size:12px;line-height:1.5}.era-active-notice strong{color:var(--text-primary)}.pulse-panel{flex-direction:column;gap:20px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.pulse-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.pulse-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.pulse-header p{color:var(--text-secondary);font-size:12px}.pulse-congestion-card{border-radius:var(--radius-lg);flex-direction:column;gap:12px;padding:16px;display:flex}.congestion-info{justify-content:space-between;align-items:center;display:flex}.congestion-label{font-size:14px;font-weight:600}.congestion-status{font-family:var(--font-heading);text-transform:uppercase;font-size:14px;font-weight:700}.congestion-bar-bg{background:#ffffff1a;border-radius:4px;width:100%;height:8px;overflow:hidden}.congestion-bar-fill{border-radius:4px;height:100%;transition:width 1s cubic-bezier(.4,0,.2,1),background-color 1s}.congestion-value{color:var(--text-muted);text-align:right;font-size:11px}.pulse-layers{flex-direction:column;gap:12px;display:flex}.pulse-layers h4{border-bottom:1px solid var(--border-glass);margin-bottom:4px;padding-bottom:8px;font-size:14px}.layer-toggle{border-radius:var(--radius-md);cursor:pointer;background:#ffffff05;border:1px solid #0000;justify-content:space-between;align-items:center;padding:12px;transition:background .2s;display:flex}.layer-toggle:hover{background:#ffffff0d}.layer-info{align-items:center;gap:12px;display:flex}.layer-icon{font-size:20px}.layer-name{font-size:14px;font-weight:600;display:block}.layer-desc{color:var(--text-muted);margin-top:2px;font-size:11px}.toggle-switch{width:40px;height:22px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch .slider{cursor:pointer;background-color:#fff3;border-radius:22px;transition:all .3s;position:absolute;inset:0}.toggle-switch .slider:before{content:"";background-color:#fff;border-radius:50%;width:16px;height:16px;transition:all .3s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.slider{background-color:#8b5cf6}.toggle-switch input:checked+.slider:before{transform:translate(18px)}.pulse-alerts{flex-direction:column;gap:12px;margin-top:8px;display:flex}.pulse-alerts h4{border-bottom:1px solid var(--border-glass);margin-bottom:4px;padding-bottom:8px;font-size:14px}.alert-list{flex-direction:column;gap:8px;list-style:none;display:flex}.alert-item{border-radius:var(--radius-sm);background:#ffffff08;border-left:3px solid #0000;align-items:flex-start;gap:10px;padding:10px;display:flex}.alert-item.warning{border-left-color:#fbbf24}.alert-item.info{border-left-color:#3b82f6}.alert-item.success{border-left-color:#4ade80}.alert-icon{margin-top:2px;font-size:16px}.alert-text{flex-direction:column;gap:2px;display:flex}.alert-text strong{font-size:13px}.alert-text span{color:var(--text-secondary);font-size:11px}.radar-panel{flex-direction:column;gap:20px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.radar-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.radar-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.radar-header p{color:var(--text-secondary);font-size:12px}.radar-controls{flex-direction:column;gap:8px;display:flex}.search-radar-btn{background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 100%);justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;display:flex}.search-radar-btn:hover:not(:disabled){box-shadow:0 0 20px #ec489966}.radar-icon{font-size:18px;animation:2s infinite pulse-ring}@keyframes pulse-ring{0%{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1.1)}to{opacity:.5;transform:scale(.95)}}.spinner-icon{animation:1s linear infinite spin}.error-text{color:#ef4444;text-align:center;font-size:12px}.radar-results{flex:1}.event-list{flex-direction:column;gap:12px;display:flex}.event-list h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;font-size:13px}.event-card{border-radius:var(--radius-lg);cursor:pointer;background:#ffffff08;gap:12px;padding:8px;transition:all .2s;display:flex}.event-card:hover{background:#ffffff14;border-left:3px solid #ec4899;transform:translate(4px)}.event-image{border-radius:var(--radius-md);object-fit:cover;width:60px;height:60px}.event-image-placeholder{border-radius:var(--radius-md);background:#0000004d;justify-content:center;align-items:center;width:60px;height:60px;font-size:24px;display:flex}.event-info{flex-direction:column;flex:1;justify-content:center;gap:4px;display:flex}.event-info h5{font-size:14px;font-weight:600;line-height:1.2}.event-meta{align-items:center;gap:8px;display:flex}.live-badge{color:#f87171;letter-spacing:.5px;background:#ef444433;border-radius:4px;padding:2px 6px;font-size:9px;font-weight:700;animation:2s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.event-rating{color:#fbbf24;font-size:11px}.event-address{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-size:11px;overflow:hidden}.empty-radar{text-align:center;border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:8px;padding:32px 16px;display:flex}.empty-icon{opacity:.5;margin-bottom:8px;font-size:32px}.empty-radar p{font-size:14px;font-weight:600}.empty-radar span{color:var(--text-muted);font-size:12px}.event-info-header{justify-content:space-between;align-items:flex-start;display:flex}.btn-bookmark{cursor:pointer;color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;transition:all .2s;display:flex}.btn-bookmark:hover{background:#fff3;transform:scale(1.1)}.btn-bookmark.active{background:#ec489933;border-color:#ec4899}.bookmarks-section{border-top:1px solid var(--border-glass);margin-top:24px;padding-top:16px}.bookmarks-section h4{color:var(--text-primary);margin-bottom:12px;font-size:14px;font-weight:600}.bookmark-card{align-items:center}.bookmark-date{color:var(--text-muted);margin-top:4px;font-size:10px;display:block}.memory-panel{flex-direction:column;gap:20px;height:100%;padding:16px;animation:.3s fadeIn;display:flex;overflow-y:auto}.memory-header{text-align:center;border-bottom:1px solid var(--border-glass);padding-bottom:12px}.memory-header h3{margin-bottom:4px;font-size:18px;font-weight:700}.memory-header p{color:var(--text-secondary);font-size:12px}.memory-stats{border-radius:var(--radius-lg);text-align:center;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px;display:grid}.stat-box{flex-direction:column;gap:4px;display:flex}.stat-label{text-transform:uppercase;color:var(--text-secondary);letter-spacing:.5px;font-size:11px}.memory-list{flex-direction:column;gap:12px;display:flex}.memory-card{border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;gap:10px;padding:16px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.memory-card:hover{transform:translateY(-2px)scale(1.02);box-shadow:0 8px 24px #0000004d}.memory-card.itinerary{border-left:3px solid #8b5cf6}.memory-card.quest{border-left:3px solid #f59e0b}.memory-card-header{justify-content:space-between;align-items:center;display:flex}.memory-type-badge{text-transform:uppercase;border-radius:12px;padding:3px 8px;font-size:10px;font-weight:700}.memory-type-badge.itinerary{color:#a78bfa;background:#8b5cf633}.memory-type-badge.quest{color:#fbbf24;background:#f59e0b33}.memory-date{color:var(--text-muted);font-size:11px}.memory-title{font-size:16px;font-weight:600}.memory-card-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.memory-count{color:var(--text-secondary);font-size:12px}.btn-delete-memory{cursor:pointer;opacity:.5;background:0 0;border:none;padding:4px;font-size:14px;transition:opacity .2s}.btn-delete-memory:hover{opacity:1}.empty-memory{text-align:center;border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:8px;padding:40px 20px;display:flex}.empty-memory .empty-icon{opacity:.5;margin-bottom:8px;font-size:40px}.empty-memory p{font-size:15px;font-weight:600}.empty-memory span{color:var(--text-muted);font-size:12px;line-height:1.5}.settings-panel{padding:24px;animation:.3s both fadeIn}.settings-section{border-bottom:1px solid var(--border-glass);margin-bottom:28px;padding-bottom:24px}.settings-section:last-child{border-bottom:none}.settings-section h3{color:var(--text-primary);margin-bottom:16px;font-size:15px}.settings-field{justify-content:space-between;align-items:center;padding:10px 0;display:flex}.field-label{color:var(--text-secondary);font-size:13px}.field-value{color:var(--text-primary);font-size:13px;font-weight:500}.plan-badge{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;background:#a78bfa26;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.quota-bar-group{flex-direction:column;gap:16px;display:flex}.quota-label{color:var(--text-secondary);justify-content:space-between;margin-bottom:6px;font-size:12px;display:flex}.quota-bar{background:#ffffff0f;border-radius:3px;width:100%;height:6px;overflow:hidden}.quota-fill{background:var(--accent-gradient);border-radius:3px;height:100%;transition:width .5s}.quota-hint{color:var(--text-muted);margin-top:12px;font-size:11px}.byok-description{color:var(--text-secondary);margin-bottom:12px;font-size:12px;line-height:1.5}.byok-input-group{flex-direction:column;gap:10px;display:flex}.byok-input{border-radius:var(--radius-sm);border:1px solid var(--border-glass);width:100%;color:var(--text-primary);background:#ffffff08;outline:none;padding:10px 14px;font-family:monospace;font-size:13px}.byok-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.byok-actions{gap:8px;display:flex}.byok-saved{color:#10b981;margin-top:8px;font-size:12px}.plan-badge.pro{color:#fff;background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 100%);border-color:#0000}.pro-unlimited-notice{border-radius:var(--radius-md);background:#ec48990d;border:1px solid #ec489933;align-items:center;gap:16px;padding:16px;display:flex}.btn-signout{border-radius:var(--radius-sm);color:#f87171;width:100%;font-family:var(--font-body);cursor:pointer;transition:all var(--transition-base);background:#ef444414;border:1px solid #ef44444d;padding:12px;font-size:14px;font-weight:600}.btn-signout:hover{background:#ef444426;border-color:#ef444480}.home-container{background:var(--bg-primary);width:100vw;height:100vh;font-family:var(--font-body);-ms-overflow-style:none;scrollbar-width:none;flex-direction:column;align-items:center;display:flex;position:relative;overflow:hidden auto}.home-container::-webkit-scrollbar{display:none}.home-bg-glow{z-index:0;pointer-events:none;background:radial-gradient(circle,#8b5cf626 0%,#0f172a00 70%);width:80vw;height:80vw;position:absolute;top:10%;left:20%;transform:translate(-50%,-50%)}.home-bg-glow-2{z-index:0;pointer-events:none;background:radial-gradient(circle,#38bdf81a 0%,#0f172a00 70%);width:90vw;height:90vw;position:absolute;top:60%;right:-20%;transform:translate(-50%,-50%)}.home-nav{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-glass);z-index:100;background:#050508cc;justify-content:space-between;align-items:center;width:100%;height:80px;padding:0 40px;display:flex;position:fixed;top:0;left:0}.home-nav-left{align-items:center;gap:12px;display:flex}.home-nav-right{align-items:center;gap:32px;display:flex}.nav-link{color:var(--text-secondary);font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.nav-link:hover{color:var(--text-primary)}.home-content{z-index:10;flex-direction:column;align-items:center;gap:120px;width:100%;max-width:1200px;padding:160px 20px 40px;display:flex;position:relative}.home-hero{text-align:center;flex-direction:column;align-items:center;gap:24px;max-width:800px;animation:1s .2s both slideUp;display:flex}.hero-badge{color:var(--accent);text-transform:uppercase;letter-spacing:1px;background:#a78bfa1a;border:1px solid #a78bfa33;border-radius:100px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-block}.hero-title{color:#fff;letter-spacing:-.03em;font-size:clamp(48px,8vw,84px);font-weight:800;line-height:1.1}.text-gradient{background:linear-gradient(135deg,#a78bfa,#f472b6,#fbbf24);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.hero-description{color:var(--text-secondary);max-width:650px;font-size:clamp(16px,2vw,20px);line-height:1.6}.hero-cta-group{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:16px;display:flex}.btn-launch{color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#d946ef);border:none;border-radius:100px;align-items:center;gap:12px;padding:16px 40px;font-size:18px;font-weight:700;transition:all .3s cubic-bezier(.34,1.56,.64,1);display:inline-flex;box-shadow:0 10px 30px #d946ef4d}.btn-launch:hover{transform:translateY(-4px)scale(1.05);box-shadow:0 20px 40px #d946ef80}.btn-launch .btn-icon{font-size:24px}.btn-secondary{color:#fff;font-family:var(--font-body);cursor:pointer;background:#ffffff0d;border:1px solid #fff3;border-radius:100px;padding:16px 32px;font-size:16px;font-weight:600;transition:all .3s}.btn-secondary:hover{background:#ffffff1a;border-color:#fff6}.home-stats{border-top:1px solid #ffffff0d;border-bottom:1px solid #ffffff0d;flex-wrap:wrap;justify-content:center;gap:64px;width:100%;padding:40px 0;display:flex}.stat-item{flex-direction:column;align-items:center;gap:8px;display:flex}.stat-value{font-size:36px;font-weight:800;font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:14px;font-weight:500}.section-header{text-align:center;margin-bottom:64px}.section-header h2{margin-bottom:16px;font-size:clamp(32px,5vw,48px);line-height:1.2}.section-header p{color:var(--text-secondary);font-size:18px}.home-features{width:100%}.features-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;display:grid}.feature-card{background:#ffffff05;border:1px solid #ffffff0d;border-radius:24px;flex-direction:column;gap:16px;padding:32px 24px;transition:all .4s;display:flex;position:relative;overflow:hidden}.feature-card:before{content:"";background:radial-gradient(circle at top right, var(--feature-color) 0%, transparent 40%);opacity:.1;width:100%;height:100%;transition:opacity .4s;position:absolute;top:0;left:0}.feature-card:hover{border-color:#ffffff1a;transform:translateY(-8px);box-shadow:0 20px 40px #0006}.feature-card:hover:before{opacity:.2}.feature-icon-circle{background:#ffffff0d;border:1px solid #ffffff0d;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:28px;display:flex}.feature-card h3{color:#fff;z-index:1;font-size:20px}.feature-card p{color:var(--text-secondary);z-index:1;font-size:15px;line-height:1.6}.home-how{width:100%}.steps-row{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:32px;display:grid}.step-card{text-align:center;background:#ffffff05;border-radius:24px;flex-direction:column;align-items:center;gap:16px;padding:40px 32px;display:flex}.step-number{background:var(--accent-gradient);color:#fff;width:48px;height:48px;font-family:var(--font-heading);border-radius:50%;justify-content:center;align-items:center;font-size:20px;font-weight:800;display:flex}.step-card h3{font-size:22px}.step-card p{color:var(--text-secondary);line-height:1.6}.home-final-cta{text-align:center;background:radial-gradient(circle,#a78bfa1a 0%,#0000 70%);border-radius:32px;width:100%;padding:80px 40px}.home-final-cta h2{margin-bottom:32px;font-size:clamp(32px,5vw,48px)}.home-footer{text-align:center;width:100%;color:var(--text-muted);border-top:1px solid #ffffff0d;padding:40px 0 20px;font-size:13px}@media (width<=768px){.home-nav{padding:0 20px}.home-nav-right .nav-link{display:none}.home-content{gap:80px;padding-top:120px}.home-stats{gap:32px}.hero-cta-group{flex-direction:column;width:100%;padding:0 20px}.btn-launch,.btn-secondary{justify-content:center;width:100%}}.auth-container{background:var(--bg-primary);-ms-overflow-style:none;scrollbar-width:none;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden auto}.auth-container::-webkit-scrollbar{display:none}.auth-bg-glow{z-index:0;pointer-events:none;background:radial-gradient(circle,#8b5cf61f 0%,#0f172a00 70%);width:600px;height:600px;position:absolute;top:30%;left:50%;transform:translate(-50%,-50%)}.auth-nav{-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-glass);z-index:100;background:#050508cc;justify-content:space-between;align-items:center;width:100%;height:80px;padding:0 40px;display:flex;position:fixed;top:0;left:0}.auth-nav-left{align-items:center;gap:12px;display:flex}.nav-logo-icon{font-size:28px}.nav-logo-text{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:24px;font-weight:800}.auth-nav-right{align-items:center;gap:32px;display:flex}.btn-nav-signin{color:var(--text-primary);font-family:var(--font-body);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:100px;padding:8px 24px;font-size:14px;font-weight:600;transition:all .3s}.btn-nav-signin:hover{border-color:var(--accent);color:var(--accent);background:#ffffff1a}.auth-card{z-index:10;border-radius:var(--radius-xl);text-align:center;width:100%;max-width:420px;padding:48px 36px;animation:.6s both fadeIn;position:relative}.auth-logo{justify-content:center;align-items:center;gap:12px;margin-bottom:32px;display:flex}.logo-icon-lg{font-size:36px;animation:4s ease-in-out infinite float}.logo-text-lg{font-family:var(--font-heading);background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:28px;font-weight:800}.auth-title{margin-bottom:8px;font-size:24px}.auth-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:14px;line-height:1.5}.google-btn-wrapper{justify-content:center;margin-bottom:20px;display:flex}.auth-divider{text-align:center;color:var(--text-muted);margin:20px 0;font-size:12px;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-glass);width:30%;height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-form{text-align:left;flex-direction:column;gap:16px;display:flex}.input-group{flex-direction:column;gap:6px;display:flex}.input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.input-group input{border-radius:var(--radius-sm);border:1px solid var(--border-glass);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition-base);background:#ffffff08;outline:none;padding:12px 16px;font-size:14px}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.input-group input::placeholder{color:var(--text-muted)}.auth-error{border-radius:var(--radius-sm);color:#f87171;background:#ef44441a;border:1px solid #ef44444d;padding:10px 14px;font-size:13px}.btn-auth-submit{border-radius:var(--radius-sm);background:var(--accent-gradient);color:#fff;width:100%;font-family:var(--font-body);cursor:pointer;border:none;margin-top:4px;padding:14px;font-size:15px;font-weight:600;transition:all .3s}.btn-auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #a78bfa66}.btn-auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-switch{color:var(--text-secondary);margin-top:24px;font-size:13px}.link-btn{color:var(--accent);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font-body);background:0 0;border:none}.link-btn:hover{text-decoration:underline}@media (width<=480px){.auth-nav{padding:0 20px}.auth-card{margin:16px;padding:32px 24px}}.upgrade-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.upgrade-modal{border-radius:var(--radius-xl);background:linear-gradient(145deg,#1e293bf2,#0f172afa);border:1px solid #ec48994d;flex-direction:column;gap:24px;width:90%;max-width:480px;padding:32px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;display:flex;position:relative;box-shadow:0 20px 40px #00000080,inset 0 0 0 1px #ffffff0d}.close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:20px;transition:color .2s;position:absolute;top:16px;right:16px}.close-btn:hover{color:#fff}.upgrade-header{text-align:center}.pro-badge{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 100%);border-radius:20px;margin-bottom:12px;padding:4px 12px;font-size:12px;font-weight:800;display:inline-block}.upgrade-header h2{margin-bottom:8px;font-size:24px;font-weight:700}.upgrade-header p{color:var(--text-secondary);font-size:14px;line-height:1.5}.upgrade-features{border-radius:var(--radius-lg);background:#0003;flex-direction:column;gap:16px;padding:20px;display:flex}.feature-item{align-items:flex-start;gap:16px;display:flex}.feature-icon{font-size:24px}.feature-item strong{color:#fff;margin-bottom:4px;font-size:14px;display:block}.feature-item p{color:var(--text-muted);font-size:12px;line-height:1.4}.upgrade-pricing{text-align:center;padding:12px 0}.price-tag{justify-content:center;align-items:flex-start;display:flex}.currency{color:var(--text-secondary);margin-top:4px;font-size:20px;font-weight:600}.amount{font-size:48px;font-weight:800;line-height:1}.period{color:var(--text-muted);align-self:flex-end;margin-bottom:8px;margin-left:4px;font-size:14px}.btn-checkout{color:#fff;border-radius:var(--radius-md);cursor:pointer;background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 100%);border:none;padding:16px;font-size:16px;font-weight:700;transition:all .2s}.btn-checkout:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #ec48994d}.btn-checkout:disabled{opacity:.5;cursor:not-allowed;filter:grayscale()}.checkout-note{text-align:center;color:var(--text-muted);font-size:11px}.app-shell{width:100%;height:100%;position:relative;overflow:hidden}.sidebar{width:var(--sidebar-width);z-index:50;border-right:1px solid var(--border-glass);border-radius:0;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-content{padding-top:calc(var(--header-height) + 24px);flex:1;overflow:hidden auto}.sidebar-places{padding:0 16px 16px}.sidebar-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;border-top:1px solid var(--border-glass);margin-bottom:10px;padding-top:12px;font-size:12px;font-weight:600}.sidebar-place-list{flex-direction:column;gap:4px;display:flex}.sidebar-place-item{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:10px;padding:8px;animation:.3s both fadeIn;display:flex}.sidebar-place-item:hover{background:#ffffff0d}.sidebar-place-item.selected{background:#a78bfa1f;border:1px solid #a78bfa33}.spi-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:40px;height:40px}.spi-no-img{background:var(--bg-tertiary);justify-content:center;align-items:center;font-size:18px;display:flex}.spi-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.spi-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.spi-meta{color:var(--text-muted);gap:8px;font-size:11px;display:flex}.spi-rating{color:#fbbf24;font-weight:600}.spi-type{text-transform:capitalize}.spi-add{border:1px solid var(--border-glass);width:26px;height:26px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.spi-add:hover{border-color:var(--accent);color:var(--accent);background:#a78bfa1a}.spi-add.added{color:#4ade80;cursor:default;background:#4ade8026;border-color:#4ade804d}.mobile-sidebar-toggle{width:100%;color:var(--text-secondary);font-family:var(--font-body);text-transform:uppercase;letter-spacing:1px;cursor:pointer;border:none;border-bottom:1px solid var(--border-glass);background:0 0;padding:12px;font-size:12px;font-weight:600;display:none}.drag-handle{background:var(--border-glass-hover);border-radius:2px;width:40px;height:4px;margin:0 auto 8px}@media (width<=768px){.app-shell{flex-direction:column;display:flex}.mobile-sidebar-toggle{display:block}.sidebar{top:auto;bottom:var(--header-height);border-right:none;border-top:1px solid var(--border-glass);z-index:40;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f172ad9;border-radius:20px 20px 0 0;width:100%;height:50vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;left:0;right:0;box-shadow:0 -4px 30px #0006}.sidebar.sidebar-hidden{transform:translateY(calc(100% - 44px))}.sidebar-content{padding-top:4px}.sidebar-places{padding-bottom:24px;display:block}.map-wrapper{top:0;left:0;right:0;bottom:var(--header-height);position:absolute}}
