:root{--bg-dark:#0d0d1a;--bg-card:#161628d9;--bg-glass:#1e1e37a6;--bg-sheet:#121223f2;--border-glass:#ffffff14;--text-primary:#f0f0f5;--text-secondary:#88a;--text-muted:#55556e;--accent:#6c5ce7;--accent-primary:#6c5ce7;--accent-glow:#6c5ce759;--success:#2ed573;--danger:#ff4757;--text-tertiary:#55556e;--nav-height:70px;--sheet-radius:22px;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--shadow-lg:0 8px 32px #00000073;--shadow-glow:0 0 20px var(--accent-glow)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-dark);height:100%;color:var(--text-primary);-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;font-family:Outfit,system-ui,-apple-system,sans-serif;overflow:hidden}#app{width:100%;height:100%;position:relative}.hidden{display:none!important}.splash{z-index:9999;background:linear-gradient(135deg,#0d0d1a 0%,#1a1a3e 50%,#0d0d1a 100%);justify-content:center;align-items:center;transition:opacity .5s,transform .5s;display:flex;position:fixed;inset:0}.splash.fade-out{opacity:0;pointer-events:none;transform:scale(1.05)}.splash-content{text-align:center;animation:.7s ease-out splashIn}.splash-icon{margin-bottom:12px;font-size:64px;animation:1.2s infinite bounce}.splash-title{letter-spacing:6px;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 50%,#6c5ce7 100%) 0 0/200% 200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:42px;font-weight:800;animation:3s infinite gradientShift}.splash-subtitle{color:var(--text-secondary);letter-spacing:1px;margin-top:8px;font-size:14px;font-weight:300}.splash-loader{background:var(--bg-glass);border-radius:4px;width:120px;height:3px;margin:28px auto 0;overflow:hidden}.loader-bar{background:linear-gradient(90deg,#6c5ce7,#a29bfe);border-radius:4px;width:0%;height:100%;animation:1.8s ease-in-out forwards loadBar}.main-app{width:100%;height:100%;position:relative}#map-container{z-index:1;width:100%;height:100%}.leaflet-control-zoom a{background:var(--bg-sheet)!important;color:var(--text-primary)!important;border-color:var(--border-glass)!important}.leaflet-control-attribution{color:var(--text-muted)!important;background:#0d0d1ab3!important;font-size:9px!important}.leaflet-control-attribution a{color:var(--text-secondary)!important}.fab{z-index:500;cursor:pointer;color:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;transition:transform .2s,box-shadow .2s;display:flex;position:fixed}.fab:active{transform:scale(.9)}.fab-pin{bottom:calc(var(--nav-height) + 24px);width:60px;height:60px;box-shadow:var(--shadow-glow), var(--shadow-lg);background:linear-gradient(135deg,#6c5ce7,#a29bfe);animation:2.5s infinite fabPulse;right:20px}.fab-location{bottom:calc(var(--nav-height) + 96px);background:var(--bg-sheet);border:1px solid var(--border-glass);width:44px;height:44px;box-shadow:var(--shadow-lg);right:20px}.fab-location:active{background:var(--accent)}.bottom-sheet{bottom:var(--nav-height);z-index:600;background:var(--bg-sheet);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-glass);border-radius:var(--sheet-radius) var(--sheet-radius) 0 0;padding:14px 20px 24px;transition:transform .35s cubic-bezier(.32,.72,0,1);position:fixed;left:0;right:0;transform:translateY(100%);box-shadow:0 -8px 40px #00000080}.bottom-sheet.show{transform:translateY(0)}.sheet-handle{background:var(--text-muted);border-radius:4px;width:36px;height:4px;margin:0 auto 14px}.sheet-title{color:var(--text-primary);margin-bottom:16px;font-size:18px;font-weight:600}.category-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.category-btn{border-radius:var(--radius-md);background:var(--bg-glass);border:none;border:1px solid var(--border-glass);color:var(--text-primary);cursor:pointer;flex-direction:column;align-items:center;gap:6px;padding:14px 6px;font-family:inherit;transition:all .2s;display:flex}.category-btn:active{transform:scale(.93)}.category-btn .cat-icon{font-size:28px;line-height:1}.category-btn .cat-label{color:var(--text-secondary);font-size:11px;font-weight:500}.category-btn:hover,.category-btn:focus{border-color:var(--accent);background:#6c5ce71a}.note-sheet{padding-bottom:28px}.note-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.note-cat-icon{font-size:28px}.note-input-wrap{gap:10px;display:flex}.note-input{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:var(--bg-glass);color:var(--text-primary);outline:none;flex:1;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.note-input:focus{border-color:var(--accent)}.note-input::placeholder{color:var(--text-muted)}.btn-drop{border-radius:var(--radius-md);color:#fff;cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;padding:14px 20px;font-family:inherit;font-size:15px;font-weight:600;transition:transform .15s,box-shadow .15s}.btn-drop:active{transform:scale(.95)}.modal-overlay{z-index:800;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0009;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-sheet);border:1px solid var(--border-glass);border-radius:var(--radius-lg);width:100%;max-width:360px;box-shadow:var(--shadow-lg);padding:28px 24px;animation:.3s cubic-bezier(.32,.72,0,1) modalIn;position:relative}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:28px;line-height:1;position:absolute;top:12px;right:16px}.modal-icon{text-align:center;margin-bottom:8px;font-size:48px}.modal-category{text-align:center;text-transform:capitalize;font-size:20px;font-weight:600}.modal-note{text-align:center;color:var(--text-secondary);word-break:break-word;margin-top:8px;font-size:14px;line-height:1.5}.modal-meta{color:var(--text-muted);justify-content:center;gap:16px;margin-top:16px;font-size:12px;display:flex}.modal-actions{flex-direction:column;align-items:center;gap:8px;margin-top:20px;display:flex}.btn-action{border-radius:var(--radius-sm);cursor:pointer;border:none;width:100%;padding:10px 24px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-gmaps{color:var(--success);background:#2ed5731f;border:1px solid #2ed57340}.btn-gmaps:active{background:var(--success);color:#fff}.btn-delete{color:var(--danger);background:#ff475726;border:1px solid #ff475740}.btn-delete:active{background:var(--danger);color:#fff}.btn-share{color:var(--accent);background:#6c5ce71f;border:1px solid #6c5ce740}.btn-share:active{background:var(--accent);color:#fff}.bottom-nav{height:var(--nav-height);z-index:700;background:var(--bg-sheet);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-glass);padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 16px;font-family:inherit;font-size:11px;font-weight:500;transition:all .2s;display:flex}.nav-btn.active{color:var(--accent)}.nav-btn.active svg{filter:drop-shadow(0 0 6px var(--accent-glow))}.panel{top:0;left:0;right:0;bottom:var(--nav-height);z-index:400;background:var(--bg-dark);-webkit-overflow-scrolling:touch;animation:.3s panelIn;position:fixed;overflow-y:auto}.panel-header{z-index:10;background:linear-gradient(to bottom, var(--bg-dark) 70%, transparent);padding:20px 20px 14px;position:sticky;top:0}.panel-header h2{font-size:28px;font-weight:700}.feed-list{padding:0 16px 20px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-icon{margin-bottom:12px;font-size:48px}.feed-item{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-glass);cursor:pointer;align-items:flex-start;gap:12px;margin-bottom:8px;padding:14px;transition:background .15s;animation:.3s backwards feedItemIn;display:flex}.feed-item:active{background:var(--bg-glass)}.feed-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:26px;display:flex}.feed-body{flex:1;min-width:0}.feed-cat{text-transform:capitalize;font-size:14px;font-weight:600}.feed-note{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:13px;overflow:hidden}.feed-time{color:var(--text-muted);margin-top:4px;font-size:11px}.gang-content{padding:0 20px 20px}.gang-actions{flex-direction:column;gap:16px;display:flex}.btn-gang{border-radius:var(--radius-md);color:#fff;cursor:pointer;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;width:100%;padding:16px;font-family:inherit;font-size:16px;font-weight:600;transition:transform .15s}.btn-gang:active{transform:scale(.97)}.btn-join{width:auto;padding:16px 28px}.btn-leave{color:var(--danger);background:#ff47571f;border:1px solid #ff475733;margin-top:20px}.gang-divider{text-align:center;color:var(--text-muted);font-size:13px;position:relative}.gang-divider:before,.gang-divider:after{content:"";background:var(--border-glass);width:40%;height:1px;position:absolute;top:50%}.gang-divider:before{left:0}.gang-divider:after{right:0}.gang-join{gap:10px;display:flex}.input-code{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:var(--bg-glass);color:var(--text-primary);letter-spacing:4px;text-align:center;text-transform:uppercase;outline:none;flex:1;padding:14px 16px;font-family:inherit;font-size:18px;font-weight:600}.input-code:focus{border-color:var(--accent)}.gang-info{margin-top:0}.gang-code-display{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-glass);align-items:center;gap:12px;margin-bottom:20px;padding:18px;display:flex}.gang-label{color:var(--text-muted);font-size:12px;font-weight:500}.gang-code-value{letter-spacing:4px;color:var(--accent);text-align:center;flex:1;font-size:24px;font-weight:700}.btn-copy{cursor:pointer;background:0 0;border:none;padding:4px;font-size:20px}.gang-members{margin-bottom:10px}.member-item{border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-glass);align-items:center;gap:12px;margin-bottom:6px;padding:12px;transition:all .2s;display:flex}.member-item:hover{background:var(--bg-glass);border-color:var(--accent)}.member-item:active{transform:scale(.98)}.member-avatar{background:var(--accent);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.member-name{font-size:14px;font-weight:500}.profile-content{flex-direction:column;align-items:center;padding:0 20px 40px;display:flex}.profile-avatar{width:80px;height:80px;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#6c5ce7,#a29bfe);border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;font-size:32px;font-weight:700;display:flex}.profile-field{width:100%;margin-bottom:24px}.profile-field label{color:var(--text-muted);margin-bottom:6px;font-size:12px;font-weight:500;display:block}.input-name{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:var(--bg-glass);width:100%;color:var(--text-primary);text-align:center;outline:none;padding:14px 16px;font-family:inherit;font-size:16px;font-weight:600}.input-name:focus{border-color:var(--accent)}.profile-stats{grid-template-columns:1fr 1fr;gap:12px;width:100%;margin-bottom:30px;display:grid}.stat-card{text-align:center;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-glass);padding:20px 10px}.stat-value{color:var(--accent);font-size:28px;font-weight:700;display:block}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.btn-danger{border-radius:var(--radius-md);color:var(--danger);cursor:pointer;background:#ff475714;border:1px solid #ff475733;padding:12px 28px;font-family:inherit;font-size:14px;font-weight:600}button,a,[role=button]{min-width:44px;min-height:44px}.leaflet-control-attribution a,.leaflet-control-attribution a:hover{min-height:unset;min-width:unset}#gps-rationale-banner{z-index:9000;color:#fff;background:linear-gradient(135deg,#6c5ce7,#a29bfe);align-items:center;gap:10px;padding:10px 16px;font-size:13px;font-weight:500;animation:.3s slideDown;display:flex;position:fixed;top:0;left:0;right:0}#gps-rationale-banner button{color:#fff;cursor:pointer;min-height:unset;background:#fff3;border:none;border-radius:6px;margin-left:auto;padding:4px 10px;font-size:12px}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}#no-gang-cta{bottom:calc(var(--nav-height) + 100px);z-index:499;background:var(--bg-sheet);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid #6c5ce740;align-items:center;gap:12px;padding:16px 18px;animation:.4s cubic-bezier(.32,.72,0,1) slideUp;display:flex;position:fixed;left:16px;right:16px}#no-gang-cta .cta-text{color:var(--text-secondary);flex:1;font-size:13px;line-height:1.4}#no-gang-cta .cta-btn{color:#fff;cursor:pointer;white-space:nowrap;min-width:unset;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;border-radius:10px;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:600}#no-gang-cta .cta-close{color:var(--text-muted);cursor:pointer;min-height:unset;min-width:unset;background:0 0;border:none;padding:0;font-size:18px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes splashIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}@keyframes loadBar{0%{width:0%}60%{width:75%}to{width:100%}}@keyframes fabPulse{0%,to{box-shadow:var(--shadow-glow), var(--shadow-lg)}50%{box-shadow:0 0 30px var(--accent-glow), var(--shadow-lg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.9)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes panelIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pinDrop{0%{opacity:0;transform:rotate(-45deg)scale(0)translateY(-30px)}to{opacity:1;transform:rotate(-45deg)scale(1)translateY(0)}}@keyframes feedItemIn{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}.toast{bottom:calc(var(--nav-height) + 20px);border-radius:var(--radius-md);background:var(--bg-sheet);border:1px solid var(--border-glass);color:var(--text-primary);box-shadow:var(--shadow-lg);z-index:9000;opacity:0;pointer-events:none;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:500;transition:all .3s;position:fixed;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.auth-screen{z-index:10000;background:linear-gradient(135deg,#0d0d1a 0%,#1a1a3e 50%,#0d0d1a 100%);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.auth-card{text-align:center;width:100%;max-width:380px}.auth-logo{margin-bottom:8px;font-size:56px;animation:1.2s infinite bounce}.auth-title{letter-spacing:4px;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 50%,#6c5ce7 100%) 0 0/200% 200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:36px;font-weight:800;animation:3s infinite gradientShift}.auth-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:13px}.auth-tabs{background:var(--bg-glass);border-radius:var(--radius-md);gap:4px;margin-bottom:20px;padding:4px;display:flex}.auth-tab{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:10px;font-family:inherit;font-size:14px;font-weight:600;transition:all .2s}.auth-tab.active{background:var(--accent);color:#fff}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-form input{border-radius:var(--radius-md);border:1px solid var(--border-glass);background:var(--bg-glass);color:var(--text-primary);outline:none;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.auth-form input:focus{border-color:var(--accent)}.auth-form input::placeholder{color:var(--text-muted)}.auth-btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;padding:14px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s;display:flex}.auth-btn:active{transform:scale(.97)}.auth-btn.primary{color:#fff;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#6c5ce7,#a29bfe)}.auth-btn.google{background:var(--bg-glass);border:1px solid var(--border-glass);color:var(--text-primary);width:100%}.auth-btn.google:hover{border-color:var(--accent)}.auth-divider{align-items:center;margin:20px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border-glass);flex:1;height:1px}.auth-divider span{color:var(--text-muted);padding:0 14px;font-size:12px}.auth-guest-section{flex-direction:column;gap:10px;margin-bottom:8px;display:flex}.auth-guest-name-wrap{width:100%}.auth-guest-input{border-radius:var(--radius-md);width:100%;color:var(--text-primary);text-align:center;background:#6c5ce70f;border:1px solid #6c5ce74d;outline:none;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}.auth-guest-input:focus{border-color:var(--accent)}.auth-guest-input::placeholder{color:var(--text-muted)}.auth-btn.guest{color:#fff;width:100%;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#6c5ce7,#a29bfe);padding:16px 24px;font-size:16px;font-weight:700}.auth-guest-note{color:var(--text-muted);font-size:11px;line-height:1.4}.auth-email-toggle{color:var(--text-secondary);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;padding:8px 0;font-family:inherit;font-size:13px;font-weight:500;text-decoration:underline;transition:color .2s}.auth-email-toggle:hover{color:var(--accent)}#guest-upgrade-banner{z-index:9500;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 50%,#6c5ce7 100%) 0 0/200% 200%;align-items:center;gap:10px;padding:10px 16px;animation:4s infinite gradientShift,.4s cubic-bezier(.32,.72,0,1) slideDown;display:flex;position:fixed;top:0;left:0;right:0}.gub-icon{flex-shrink:0;font-size:18px}.gub-text{color:#fff;flex:1;font-size:12px;font-weight:600;line-height:1.3}.gub-btn{color:#fff;cursor:pointer;white-space:nowrap;min-height:unset;min-width:unset;background:#ffffff26;border:1.5px solid #fff6;border-radius:8px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:700;transition:background .2s}.gub-btn:active{background:#ffffff4d}.gub-close{color:#fff9;cursor:pointer;min-height:unset;min-width:unset;background:0 0;border:none;padding:0 2px;font-size:18px}body.guest-banner-active .main-app{padding-top:40px}.gang-add-people-card{background:linear-gradient(160deg,#6c5ce71f 0%,#1e1e3799 100%);border:1px solid #6c5ce740;border-radius:16px;margin-bottom:14px;padding:16px 18px}.gap-title{text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:12px;font-size:10px;font-weight:700}.gap-btn{border:1px solid var(--border-glass);width:100%;color:var(--text-primary);cursor:pointer;min-height:unset;background:#ffffff0a;border-radius:10px;align-items:center;gap:10px;margin-bottom:8px;padding:12px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s;display:flex}.gap-btn:active{border-color:var(--accent);background:#6c5ce71f}.gap-btn-primary{color:var(--accent);background:#6c5ce71a;border-color:#6c5ce74d}.gap-code-row{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:10px;align-items:center;gap:10px;margin-bottom:8px;padding:10px 14px;display:flex}.gap-code-label{color:var(--text-muted);font-size:11px;font-weight:500}.gap-code-value{letter-spacing:3px;color:var(--accent);text-align:center;flex:1;font-size:18px;font-weight:700}.gap-btn-copy{color:var(--accent);cursor:pointer;min-height:unset;min-width:unset;background:#6c5ce726;border:1px solid #6c5ce74d;border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600}.gap-ghost-wrap{gap:8px;margin-top:8px;display:flex}.gap-ghost-input{border:1px solid var(--border-glass);background:var(--bg-glass);color:var(--text-primary);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:13px;transition:border-color .2s}.gap-ghost-input:focus{border-color:var(--accent)}.gap-ghost-input::placeholder{color:var(--text-muted)}.gap-btn-ghost{color:var(--accent);cursor:pointer;white-space:nowrap;min-height:unset;min-width:unset;background:#6c5ce733;border:none;border-radius:10px;padding:10px 14px;font-family:inherit;font-size:13px;font-weight:600}.gap-ghost-list{margin-top:8px}.gap-ghost-row{background:#ffa5020a;border:1px solid #ffa50233;border-radius:10px;align-items:center;gap:10px;margin-bottom:6px;padding:10px 12px;display:flex}.gap-ghost-avatar{color:#ffa502;background:#ffa50226;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:700;display:flex}.gap-ghost-info{flex:1;min-width:0}.gap-ghost-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.gap-ghost-status{color:#ffa502;margin-top:1px;font-size:10px;font-weight:500;display:block}.gap-ghost-share{color:var(--accent);cursor:pointer;white-space:nowrap;min-height:unset;min-width:unset;background:#6c5ce71a;border:1px solid #6c5ce74d;border-radius:8px;padding:5px 10px;font-family:inherit;font-size:11px;font-weight:600}.gap-ghost-remove{color:var(--text-muted);cursor:pointer;min-height:unset;min-width:unset;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.empty-cta-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;width:100%;max-width:280px;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;margin:16px auto 0;padding:14px 24px;font-family:inherit;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s;display:block}.empty-cta-btn:active{transform:scale(.97)}.onboarding-overlay{z-index:99999;background:linear-gradient(135deg,#0d0d1a 0%,#1a1a3e 50%,#0d0d1a 100%);justify-content:center;align-items:center;padding:24px;transition:opacity .4s;animation:.4s fadeIn;display:flex;position:fixed;inset:0}.onboarding-overlay.fade-out{opacity:0;pointer-events:none}.onboarding-card{text-align:center;max-width:340px;animation:.4s cubic-bezier(.32,.72,0,1) modalIn}.onboarding-emoji{margin-bottom:16px;font-size:72px;animation:1.5s infinite bounce}.onboarding-title{letter-spacing:1px;background:linear-gradient(135deg,#6c5ce7 0%,#a29bfe 50%,#6c5ce7 100%) 0 0/200% 200%;-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:12px;font-size:28px;font-weight:800;animation:3s infinite gradientShift}.onboarding-desc{color:var(--text-secondary);margin-bottom:28px;font-size:15px;line-height:1.6}.onboarding-dots{justify-content:center;gap:8px;margin-bottom:24px;display:flex}.onboarding-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px;transition:all .3s}.onboarding-dot.active{background:var(--accent);border-radius:4px;width:24px}.onboarding-btn{border-radius:var(--radius-md);color:#fff;cursor:pointer;width:100%;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;padding:16px 32px;font-family:inherit;font-size:16px;font-weight:700;transition:transform .15s,box-shadow .15s;display:block}.onboarding-btn:active{transform:scale(.97)}.onboarding-skip{width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;margin-top:12px;padding:10px;font-family:inherit;font-size:13px;font-weight:500;display:block}.onboarding-skip:hover{color:var(--text-secondary)}.skeleton-item{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-glass);align-items:center;gap:12px;margin-bottom:8px;padding:14px;display:flex}.skeleton-avatar{background:var(--bg-glass);border-radius:10px;flex-shrink:0;width:36px;height:36px}.skeleton-lines{flex-direction:column;flex:1;gap:6px;display:flex}.skeleton-line{background:var(--bg-glass);border-radius:6px;height:12px}.shimmer{background:linear-gradient(90deg,#ffffff08 25%,#ffffff14 50%,#ffffff08 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state-inline{text-align:center;border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-glass);flex-direction:column;align-items:center;padding:24px 16px;display:flex}.offline-banner{z-index:9998;color:#fff;text-align:center;background:linear-gradient(135deg,#e67e22,#f39c12);padding:10px 16px;font-size:13px;font-weight:600;transition:transform .3s cubic-bezier(.32,.72,0,1);position:fixed;top:0;left:0;right:0;transform:translateY(-100%)}.offline-banner.show{transform:translateY(0)}.upsell-overlay{z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;padding:24px;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.upsell-overlay.fade-out{opacity:0;transition:opacity .3s}.upsell-card{background:var(--bg-sheet);width:100%;max-width:360px;box-shadow:0 8px 40px #6c5ce733, var(--shadow-lg);text-align:center;border:1px solid #6c5ce74d;border-radius:24px;padding:32px 24px 24px;animation:.4s cubic-bezier(.32,.72,0,1) modalIn;position:relative}.upsell-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:28px;position:absolute;top:12px;right:16px}.upsell-badge{margin-bottom:8px;font-size:48px}.upsell-title{margin-bottom:6px;font-size:20px;font-weight:700}.upsell-desc{color:var(--text-secondary);margin-bottom:20px;font-size:13px}.upsell-features{text-align:left;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;display:grid}.upsell-feature{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.upsell-feature span{font-size:14px}.upsell-pricing{gap:10px;margin-bottom:14px;display:flex}.upsell-plan{border:1px solid var(--border-glass);color:var(--text-primary);cursor:pointer;background:#ffffff0a;border-radius:14px;flex:1;padding:14px 10px;font-family:inherit;transition:all .2s;position:relative}.upsell-plan:hover,.upsell-plan:focus{border-color:var(--accent);background:#6c5ce71a}.upsell-plan.best-value{background:#6c5ce714;border-color:#6c5ce766}.plan-badge{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border-radius:6px;padding:2px 10px;font-size:9px;font-weight:700;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.plan-price{color:var(--accent);font-size:18px;font-weight:700;display:block}.plan-period{color:var(--text-muted);margin-top:2px;font-size:11px;display:block}.upsell-footer{color:var(--text-muted);font-size:11px}@media (width>=768px){.category-grid{grid-template-columns:repeat(7,1fr)}}.nav-badge{background:var(--danger);color:#fff;min-width:16px;height:16px;box-shadow:0 0 0 2px var(--bg-sheet);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;font-size:9px;font-weight:800;line-height:1;animation:.3s cubic-bezier(.34,1.56,.64,1) badgePop;display:flex;position:absolute;top:-4px;right:-6px}@keyframes badgePop{0%{transform:scale(0)}to{transform:scale(1)}}.nav-avatar-dot{color:#a29bfe;background:#6c5ce733;border:1.5px solid #6c5ce7;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;transition:all .2s;display:flex}.nav-btn.active .nav-avatar-dot{box-shadow:0 0 8px #6c5ce780}.profile-hero{border-bottom:1px solid var(--border-glass);background:linear-gradient(160deg,#6c5ce71f 0%,#161628e6 100%);align-items:center;gap:16px;padding:32px 20px 24px;display:flex}.profile-hero-avatar-wrap{flex-shrink:0;position:relative}.profile-hero-avatar{background:#6c5ce733;border:2px solid #6c5ce7;border-radius:50%;justify-content:center;align-items:center;width:76px;height:76px;font-size:30px;font-weight:800;transition:all .3s;display:flex;box-shadow:0 0 20px #6c5ce759}.profile-online-dot{background:var(--success);border:2.5px solid var(--bg-dark);border-radius:50%;width:14px;height:14px;position:absolute;bottom:2px;right:2px;box-shadow:0 0 8px #2ed57399}.profile-hero-name-wrap{flex:1;min-width:0}#profile-display-name-row{align-items:center;gap:8px;display:flex}.profile-hero-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:20px;font-weight:700;overflow:hidden}.profile-edit-btn{color:var(--accent);cursor:pointer;min-height:unset;min-width:unset;background:#6c5ce726;border:1px solid #6c5ce74d;border-radius:8px;flex-shrink:0;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:600}.profile-name-input{border:1px solid var(--accent);background:var(--bg-glass);color:var(--text-primary);border-radius:10px;outline:none;flex:1;padding:8px 12px;font-family:inherit;font-size:15px;font-weight:600}.profile-save-btn{background:var(--accent);color:#fff;cursor:pointer;min-height:unset;min-width:unset;border:none;border-radius:10px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:700}.profile-cancel-btn{border:1px solid var(--border-glass);color:var(--text-muted);cursor:pointer;min-height:unset;min-width:unset;background:0 0;border-radius:10px;padding:8px 12px;font-family:inherit;font-size:13px}.profile-hero-handle{color:var(--accent);letter-spacing:.3px;margin-top:4px;font-size:13px;font-weight:600}.profile-hero-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:3px;font-size:11px;overflow:hidden}.profile-stats-row{border-bottom:1px solid var(--border-glass);align-items:center;gap:0;padding:16px 20px;display:flex}.pstat{text-align:center;flex:1}.pstat-val{color:var(--accent);font-size:22px;font-weight:800;line-height:1.1;display:block}.pstat-lbl{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;font-size:10px;font-weight:500;display:block}.pstat-divider{background:var(--border-glass);flex-shrink:0;width:1px;height:36px}.profile-sections{padding-bottom:40px}.profile-section{border-bottom:1px solid var(--border-glass);margin-bottom:0}.profile-section-title{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);padding:14px 20px 6px;font-size:11px;font-weight:700}.profile-section-danger .profile-section-title{color:var(--danger)}.profile-row-btn{border:none;border-top:1px solid var(--border-glass);color:var(--text-primary);cursor:pointer;text-align:left;width:100%;min-height:unset;background:0 0;align-items:center;gap:12px;padding:14px 20px;font-family:inherit;font-size:14px;font-weight:500;transition:background .15s;display:flex}.profile-row-btn:active{background:var(--bg-glass)}.prb-icon{text-align:center;flex-shrink:0;width:22px;font-size:18px}.prb-label{flex:1}.prb-arrow{color:var(--text-muted);font-size:18px;font-weight:400}.gang-invite-card{background:linear-gradient(135deg,#6c5ce72e 0%,#a29bfe14 100%);border:1px solid #6c5ce74d;border-radius:16px;margin-bottom:14px;padding:16px 18px;box-shadow:0 4px 24px #6c5ce71f}.btn-invite-action{color:var(--accent);cursor:pointer;min-height:unset;min-width:unset;background:#6c5ce733;border:1px solid #6c5ce74d;border-radius:10px;padding:9px 14px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-invite-action:active{background:var(--accent);color:#fff}.btn-invite-share{color:#fff;cursor:pointer;letter-spacing:.2px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;border-radius:12px;width:100%;padding:13px;font-family:inherit;font-size:14px;font-weight:700;transition:transform .15s,box-shadow .15s;box-shadow:0 4px 16px #6c5ce74d}.btn-invite-share:active{transform:scale(.97)}
