:root{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--bg-tertiary-rgb: 22, 33, 62;--bg-card: rgba(26, 26, 46, .8);--accent-primary: #667eea;--accent-secondary: #764ba2;--accent-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--accent-glow: rgba(102, 126, 234, .4);--text-primary: #f0f0f0;--text-secondary: #a0a0b8;--text-muted: #6b6b80;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 3rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .2);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;overflow:hidden;line-height:1.5;-webkit-font-smoothing:antialiased;transition:background-color var(--transition-slow);background-color:var(--bg-primary);background-image:var(--bg-image, none);background-size:var(--bg-size, auto);background-repeat:repeat;background-position:center;background-attachment:fixed}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-overlay, rgba(15, 15, 35, 0));z-index:-1;pointer-events:none}.theme-default{--theme-name: "default"}.theme-midnight{--bg-primary: #050510;--bg-secondary: rgba(20, 20, 35, .95);--bg-tertiary: rgba(30, 30, 50, .8);--bg-image: url(/assets/bg-midnight-Bjsdua5e.png);--bg-size: 300px;--accent-primary: #a855f7;--accent-secondary: #7e22ce;--accent-gradient: linear-gradient(135deg, #a855f7 0%, #7e22ce 100%);--accent-glow: rgba(168, 85, 247, .4)}.theme-forest{--bg-primary: #051005;--bg-secondary: rgba(20, 35, 20, .95);--bg-tertiary: rgba(30, 50, 30, .8);--bg-image: url(/assets/bg-forest-Cb0Bzhkx.png);--bg-size: 300px;--accent-primary: #10b981;--accent-secondary: #059669;--accent-gradient: linear-gradient(135deg, #10b981 0%, #059669 100%);--accent-glow: rgba(16, 185, 129, .4)}.theme-funky{--bg-primary: #101018;--bg-secondary: rgba(30, 30, 40, .95);--bg-tertiary: rgba(45, 45, 60, .8);--bg-image: url(/assets/bg-funky-BeZ6IWUI.png);--bg-size: 400px;--accent-primary: #f472b6;--accent-secondary: #db2777;--accent-gradient: linear-gradient(135deg, #f472b6 0%, #db2777 100%);--accent-glow: rgba(244, 114, 182, .4)}.theme-doodle-cool{--bg-primary: #101015;--bg-secondary: rgba(30, 30, 35, .95);--bg-tertiary: rgba(40, 40, 50, .8);--bg-image: url(/assets/bg-doodle-cool-DlpVjSvs.png);--bg-size: 400px;--bg-overlay: rgba(16, 16, 21, .85);--accent-primary: #60a5fa;--accent-secondary: #3b82f6;--accent-gradient: linear-gradient(135deg, #60a5fa 0%, #3b82f6 100%);--accent-glow: rgba(96, 165, 250, .4)}.theme-doodle-fun{--bg-primary: #151015;--bg-secondary: rgba(35, 30, 35, .95);--bg-tertiary: rgba(50, 40, 50, .8);--bg-image: url(/assets/bg-doodle-fun-Dse0b3lS.png);--bg-size: 350px;--bg-overlay: rgba(21, 16, 21, .85);--accent-primary: #facc15;--accent-secondary: #eab308;--accent-gradient: linear-gradient(135deg, #facc15 0%, #eab308 100%);--accent-glow: rgba(250, 204, 21, .4)}.theme-doodle-icons{--bg-primary: #101515;--bg-secondary: rgba(30, 35, 35, .95);--bg-tertiary: rgba(40, 50, 50, .8);--bg-image: url(/assets/bg-doodle-icons-Bp-Okm5J.png);--bg-size: 300px;--bg-overlay: rgba(16, 21, 21, .85);--accent-primary: #2dd4bf;--accent-secondary: #14b8a6;--accent-gradient: linear-gradient(135deg, #2dd4bf 0%, #14b8a6 100%);--accent-glow: rgba(45, 212, 191, .4)}.theme-neon-tokyo{--bg-primary: #050518;--bg-secondary: rgba(10, 10, 40, .95);--bg-tertiary: rgba(20, 20, 60, .8);--bg-image: url(/assets/bg_neon_tokyo.png);--bg-overlay: rgba(5, 5, 20, .7);--accent-primary: #00fff2;--accent-secondary: #ff0099;--accent-gradient: linear-gradient(135deg, #00fff2 0%, #ff0099 100%);--accent-glow: rgba(0, 255, 242, .4);--text-primary: #ffffff}.theme-sunset-vibes{--bg-primary: #1a0515;--bg-secondary: rgba(35, 10, 25, .95);--bg-tertiary: rgba(55, 20, 40, .8);--bg-image: url(/assets/bg_sunset_vibes.png);--bg-overlay: rgba(26, 5, 21, .6);--accent-primary: #ff9a9e;--accent-secondary: #ff6b6b;--accent-gradient: linear-gradient(135deg, #ff9a9e 0%, #ff6b6b 100%);--accent-glow: rgba(255, 154, 158, .4)}.theme-matrix{--bg-primary: #000500;--bg-secondary: rgba(0, 20, 0, .95);--bg-tertiary: rgba(0, 35, 0, .8);--bg-image: url(/assets/bg_matrix.png);--bg-overlay: rgba(0, 10, 0, .8);--accent-primary: #00ff41;--accent-secondary: #008f11;--accent-gradient: linear-gradient(135deg, #00ff41 0%, #008f11 100%);--accent-glow: rgba(0, 255, 65, .4);--text-primary: #e0ffe0}.theme-abstract-art{--bg-primary: #101010;--bg-secondary: rgba(25, 25, 25, .95);--bg-tertiary: rgba(40, 40, 40, .8);--bg-image: url(/assets/bg_abstract_art.png);--bg-overlay: rgba(16, 16, 16, .75);--accent-primary: #d4af37;--accent-secondary: #8b0000;--accent-gradient: linear-gradient(135deg, #d4af37 0%, #8b0000 100%);--accent-glow: rgba(212, 175, 55, .4)}.theme-gridlock{--accent-primary: #ff00ff;--accent-secondary: #00ffff;--accent-gradient: linear-gradient(135deg, #ff00ff 0%, #00ffff 100%);--accent-glow: rgba(255, 0, 255, .4)}.theme-retro-terminal{--bg-primary: #0a0500;--bg-secondary: rgba(20, 10, 0, .95);--bg-tertiary: rgba(30, 15, 0, .8);--bg-image: url(/assets/bg_retro_terminal.png);--bg-overlay: rgba(10, 5, 0, .75);--accent-primary: #ffb000;--accent-secondary: #ff8000;--accent-gradient: linear-gradient(135deg, #ffb000 0%, #ff8000 100%);--accent-glow: rgba(255, 176, 0, .4);--text-primary: #ffdd99}.theme-deep-space{--bg-primary: #050510;--bg-secondary: rgba(15, 15, 30, .95);--bg-tertiary: rgba(25, 25, 45, .8);--bg-image: url(/assets/bg_deep_space.png);--bg-overlay: rgba(5, 5, 15, .6);--accent-primary: #8b5cf6;--accent-secondary: #6366f1;--accent-gradient: linear-gradient(135deg, #8b5cf6 0%, #6366f1 100%);--accent-glow: rgba(139, 92, 246, .5)}.theme-cherry-blossom{--bg-primary: #15050a;--bg-secondary: rgba(30, 10, 18, .95);--bg-tertiary: rgba(45, 20, 30, .8);--bg-image: url(/assets/bg_cherry_blossom.png);--bg-overlay: rgba(20, 5, 10, .7);--accent-primary: #fbcfe8;--accent-secondary: #f472b6;--accent-gradient: linear-gradient(135deg, #fbcfe8 0%, #f472b6 100%);--accent-glow: rgba(251, 207, 232, .4);--text-primary: #fff0f5}.theme-urban-concrete{--bg-primary: #121212;--bg-secondary: rgba(30, 30, 30, .95);--bg-tertiary: rgba(45, 45, 45, .8);--bg-image: url(/assets/bg_urban_concrete.png);--bg-overlay: rgba(10, 10, 10, .7);--accent-primary: #f97316;--accent-secondary: #ea580c;--accent-gradient: linear-gradient(135deg, #f97316 0%, #ea580c 100%);--accent-glow: rgba(249, 115, 22, .4)}.theme-rainbow-road{--bg-primary: #000000;--bg-secondary: rgba(15, 15, 15, .95);--bg-tertiary: rgba(30, 30, 30, .8);--bg-image: url(/assets/bg_rainbow_road.png);--bg-overlay: rgba(5, 5, 5, .8);--accent-primary: #ffffff;--accent-secondary: #cccccc;--accent-gradient: linear-gradient(45deg, #ff0000, #ff7f00, #ffff00, #00ff00, #0000ff, #4b0082, #9400d3);--accent-glow: rgba(255, 255, 255, .3)}.theme-doodle-marine{--bg-primary: #001f3f;--bg-secondary: rgba(0, 40, 70, .95);--bg-tertiary: rgba(0, 60, 90, .8);--bg-image: url(/assets/bg_doodle_marine.png);--bg-size: 350px;--bg-overlay: rgba(0, 31, 63, .8);--accent-primary: #7fdbff;--accent-secondary: #0074d9;--accent-gradient: linear-gradient(135deg, #7fdbff 0%, #0074d9 100%);--accent-glow: rgba(127, 219, 255, .4)}.theme-doodle-kittens{--bg-primary: #292929;--bg-secondary: rgba(50, 50, 50, .95);--bg-tertiary: rgba(70, 70, 70, .8);--bg-image: url(/assets/bg_doodle_kittens.png);--bg-size: 350px;--bg-overlay: rgba(41, 41, 41, .85);--accent-primary: #ffb7b2;--accent-secondary: #ff6961;--accent-gradient: linear-gradient(135deg, #ffb7b2 0%, #ff6961 100%);--accent-glow: rgba(255, 183, 178, .4)}.theme-doodle-fastfood{--bg-primary: #3d0000;--bg-secondary: rgba(80, 10, 10, .95);--bg-tertiary: rgba(110, 20, 20, .8);--bg-image: url(/assets/bg_doodle_fastfood.png);--bg-size: 400px;--bg-overlay: rgba(61, 0, 0, .85);--accent-primary: #ffd700;--accent-secondary: #ff4500;--accent-gradient: linear-gradient(135deg, #ffd700 0%, #ff4500 100%);--accent-glow: rgba(255, 215, 0, .4)}.theme-doodle-pirates{--bg-primary: #101010;--bg-secondary: rgba(25, 25, 30, .95);--bg-tertiary: rgba(40, 40, 50, .8);--bg-image: url(/assets/bg_doodle_pirates.png);--bg-size: 400px;--bg-overlay: rgba(16, 16, 16, .8);--accent-primary: #ffd700;--accent-secondary: #8b0000;--accent-gradient: linear-gradient(135deg, #ffd700 0%, #8b0000 100%);--accent-glow: rgba(255, 215, 0, .3)}.theme-doodle-tattoos{--bg-primary: #1a1a1a;--bg-secondary: rgba(40, 40, 40, .95);--bg-tertiary: rgba(60, 60, 60, .8);--bg-image: url(/assets/bg_doodle_tattoos.png);--bg-size: 350px;--bg-overlay: rgba(26, 26, 26, .85);--accent-primary: #ff5252;--accent-secondary: #d32f2f;--accent-gradient: linear-gradient(135deg, #ff5252 0%, #d32f2f 100%);--accent-glow: rgba(255, 82, 82, .4)}.theme-doodle-buildings{--bg-primary: #2c3e50;--bg-secondary: rgba(44, 62, 80, .95);--bg-tertiary: rgba(52, 73, 94, .8);--bg-image: url(/assets/bg_doodle_buildings.png);--bg-size: 400px;--bg-overlay: rgba(44, 62, 80, .85);--accent-primary: #e67e22;--accent-secondary: #d35400;--accent-gradient: linear-gradient(135deg, #e67e22 0%, #d35400 100%);--accent-glow: rgba(230, 126, 34, .4)}.theme-skate-life{--bg-primary: #1a1a1a;--bg-secondary: rgba(30, 30, 30, .95);--bg-tertiary: rgba(45, 45, 45, .8);--bg-image: url(/assets/bg_skate_life.png);--bg-overlay: rgba(10, 10, 10, .7);--accent-primary: #76ff03;--accent-secondary: #64dd17;--accent-gradient: linear-gradient(135deg, #76ff03 0%, #64dd17 100%);--accent-glow: rgba(118, 255, 3, .4);--text-primary: #eeeeee}.theme-snow-day{--bg-primary: #0f172a;--bg-secondary: rgba(30, 41, 59, .95);--bg-tertiary: rgba(51, 65, 85, .8);--bg-image: url(/assets/bg_snow_day.png);--bg-overlay: rgba(15, 23, 42, .6);--accent-primary: #38bdf8;--accent-secondary: #0ea5e9;--accent-gradient: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 100%);--accent-glow: rgba(56, 189, 248, .4);--text-primary: #f0f9ff}#app{width:100%;height:100vh;height:100dvh;position:relative;overflow:hidden}.screen{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.screen.active{opacity:1;visibility:visible}#loading-screen{justify-content:center;align-items:center}.loading-content{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl)}.logo-pulse{width:120px;height:120px;border-radius:var(--radius-full);background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;animation:pulse 2s ease-in-out infinite;box-shadow:var(--shadow-glow)}.logo-number{font-size:var(--font-size-3xl);font-weight:700;color:#fff}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 20px var(--accent-glow)}50%{transform:scale(1.05);box-shadow:0 0 40px var(--accent-glow)}}.loading-text{font-size:var(--font-size-lg);color:var(--text-secondary)}.loading-bar{width:200px;height:4px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.loading-progress{width:30%;height:100%;background:var(--accent-gradient);border-radius:var(--radius-full);animation:loading 1.5s ease-in-out infinite}@keyframes loading{0%{transform:translate(-100%)}50%{transform:translate(200%)}to{transform:translate(-100%)}}#permission-screen{justify-content:center;align-items:center;padding:var(--space-xl)}.permission-content{max-width:340px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.icon-wrapper{width:80px;height:80px;border-radius:var(--radius-full);background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-md)}.location-icon{width:40px;height:40px;color:var(--accent-primary)}.permission-content h1{font-size:var(--font-size-xl);font-weight:600}.permission-content p{color:var(--text-secondary);font-size:var(--font-size-md)}.btn-primary{width:100%;padding:var(--space-md) var(--space-xl);font-size:var(--font-size-md);font-weight:600;color:#fff;background:var(--accent-gradient);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-md)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn-primary:active{transform:translateY(0)}.privacy-note{font-size:var(--font-size-xs);color:var(--text-muted)}#chat-screen{padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom)}.chat-header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-left{justify-self:start;display:flex;align-items:center}.header-center{justify-self:center;display:flex;align-items:center}.header-right{justify-self:end;display:flex;align-items:center;gap:var(--space-sm)}#menu-btn{width:48px;height:48px}#menu-btn svg{width:28px;height:28px}.member-count{color:var(--accent-primary);font-weight:600}.header-dot{color:var(--text-muted)}.chain-status{display:flex;align-items:center;justify-content:center;width:24px;height:16px}.chain-status svg{display:none;width:100%;height:100%}.chain-status.connected .chain-connected{display:block;stroke:var(--accent-primary);filter:drop-shadow(0 0 4px var(--accent-glow))}.chain-status.connecting .chain-connecting{display:block;stroke:var(--accent-primary);opacity:.7}.chain-status.connecting .chain-link-left{animation:chain-link-left 1.5s ease-in-out infinite}.chain-status.connecting .chain-link-right{animation:chain-link-right 1.5s ease-in-out infinite}@keyframes chain-link-left{0%,to{transform:translate(0)}50%{transform:translate(4px)}}@keyframes chain-link-right{0%,to{transform:translate(0)}50%{transform:translate(-4px)}}.chain-status.disconnected .chain-disconnected{display:block;stroke:var(--text-muted);opacity:.5}.icon-btn{width:40px;height:40px;border-radius:var(--radius-full);background:transparent;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast)}.icon-btn svg{width:20px;height:20px;color:currentColor}.icon-btn:hover{background:var(--bg-tertiary)}.messages-container{flex:1;overflow-y:auto;padding:var(--space-md);display:flex;flex-direction:column}.messages{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:auto}.message{max-width:85%;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.sent{align-self:flex-end}.message.received{align-self:flex-start}.message-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs);padding:0 var(--space-sm)}.message-avatar{width:24px;height:24px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:600;color:#fff}.message-author{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.4)}.message-distance{font-size:var(--font-size-xs);color:var(--accent-primary);font-weight:500;opacity:.8}.message-bubble{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);line-height:1.4;overflow-wrap:break-word;word-break:break-word}.message-bubble a{color:inherit;text-decoration:underline;opacity:.9}.message-bubble a:hover{opacity:1}.message.sent .message-bubble a{color:#fff}.message.received .message-bubble a{color:var(--accent-primary)}.message.sent .message-bubble{background:var(--accent-gradient);color:#fff;border-bottom-right-radius:var(--space-xs)}.message.received .message-bubble{background:rgba(var(--bg-tertiary-rgb),.9);color:var(--text-primary);border-bottom-left-radius:var(--space-xs);text-shadow:0 1px 1px rgba(0,0,0,.2)}#access-gate-screen{display:flex;align-items:center;justify-content:center;position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-primary);z-index:10000;flex-direction:column}#age-gate-screen{display:flex;align-items:flex-start;overflow-y:auto;padding:var(--space-xl);background:var(--bg-primary);z-index:9999;-webkit-overflow-scrolling:touch}.age-gate-content{width:100%;max-width:450px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);margin:auto;padding-bottom:var(--space-xl)}.warning-box{background:#ef44441a;border:1px solid var(--error);border-radius:var(--radius-md);padding:var(--space-md);color:#fcc;font-size:var(--font-size-sm);line-height:1.5}.warning-box strong{color:var(--error);display:block;margin-bottom:var(--space-xs);font-size:var(--font-size-md)}.agreement-text{font-size:var(--font-size-md);color:var(--text-primary)}.agreement-list{text-align:left;color:var(--text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--space-sm);padding-left:var(--space-lg)}.agreement-list li{margin-bottom:var(--space-xs)}.legal-link{color:var(--accent-primary);text-decoration:underline}.legal-link:hover{color:var(--accent-secondary)}.message-time{font-size:var(--font-size-xs);color:var(--text-muted);text-align:right;margin-top:var(--space-xs);padding-right:var(--space-sm)}.message.system{align-self:center;max-width:none}.message.system .message-bubble{background:transparent;color:var(--text-muted);font-size:var(--font-size-sm);padding:var(--space-sm)}.typing-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);color:var(--text-muted);font-size:var(--font-size-sm);transition:opacity var(--transition-fast)}.typing-indicator.hidden{opacity:0;height:0;padding:0;overflow:hidden}.typing-dots{display:flex;gap:4px}.typing-dots span{width:6px;height:6px;background:var(--text-muted);border-radius:var(--radius-full);animation:typingDot 1.4s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.message-form{padding:var(--space-md);background:var(--bg-secondary);border-top:1px solid rgba(255,255,255,.05)}.input-wrapper{display:flex;align-items:center;gap:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-xl);padding:var(--space-xs) var(--space-xs) var(--space-xs) var(--space-md)}#message-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:var(--font-size-md);font-family:var(--font-family);padding:var(--space-sm) 0;outline:none}#message-input::placeholder{color:var(--text-muted)}.send-btn{width:44px;height:44px;border-radius:var(--radius-full);background:var(--accent-gradient);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform var(--transition-fast),opacity var(--transition-fast);opacity:.5}.send-btn:not(:disabled){opacity:1}.send-btn:not(:disabled):hover{transform:scale(1.05)}.send-btn:not(:disabled):active{transform:scale(.95)}.send-btn svg{width:20px;height:20px;color:#fff;transform:translate(1px)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:100;display:flex;align-items:flex-end;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.modal.hidden{opacity:0;visibility:hidden}.modal-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);flex-shrink:0;padding-bottom:var(--space-md);border-bottom:1px solid rgba(255,255,255,.1)}.modal-title-group,.modal-actions{display:flex;align-items:center;gap:var(--space-sm)}.member-count-pro{font-size:.9rem;color:var(--accent-primary);font-weight:600;background:#ffffff0d;padding:2px 8px;border-radius:12px}.members-list{display:flex;flex-direction:column;gap:var(--space-md);flex:1;overflow-y:auto;min-height:200px}.modal-content{position:relative;width:100%;max-width:500px;margin:0 auto;max-height:85vh;background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-lg);padding-bottom:calc(var(--space-lg) + var(--safe-area-bottom));transform:translateY(0);transition:transform var(--transition-normal);display:flex;flex-direction:column}.modal-header h2{font-size:var(--font-size-lg);font-weight:600}.members-list{display:flex;flex-direction:column;gap:var(--space-sm);flex:1;overflow-y:auto;min-height:0;padding-right:var(--space-xs)}.member-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md)}.member-avatar{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.member-info{flex:1}.member-name{font-weight:500}.member-status{font-size:var(--font-size-sm);color:var(--text-muted)}.member-item.you .member-name:after{content:" (you)";color:var(--accent-primary);font-weight:400}.status-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--success)}.member-distance{font-size:var(--font-size-sm);font-weight:600;color:var(--accent-primary);background:#667eea26;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);margin-right:var(--space-sm)}.hidden{display:none!important}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:var(--radius-full)}@media(min-width:768px){.modal{align-items:center;justify-content:center;padding:var(--space-xl)}.modal-content{max-width:400px;max-height:60vh;border-radius:var(--radius-xl)}.modal.hidden .modal-content{transform:translateY(20px)}.message{max-width:70%}#chat-screen{display:flex;flex-direction:column;align-items:center}.chat-header{width:100%;max-width:800px;margin:0 auto;border-radius:0 0 var(--radius-lg) var(--radius-lg);border-left:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.05)}.messages-container{width:100%;max-width:800px;margin:0 auto}.message-form{width:100%;max-width:800px;margin:0 auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-left:1px solid rgba(255,255,255,.05);border-right:1px solid rgba(255,255,255,.05)}.message-author{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-shadow:0 1px 2px rgba(0,0,0,.5)}.message-bubble{text-shadow:0 1px 2px rgba(0,0,0,.3)}.message.received .message-bubble{background:rgba(var(--bg-tertiary-rgb, 22, 33, 62),.95)}.welcome-message{font-size:var(--font-size-md);text-shadow:0 1px 3px rgba(0,0,0,.5)}}@media(min-width:1024px){.chat-header,.messages-container,.message-form{max-width:900px}.message{max-width:65%}.messages-container{padding:var(--space-lg) var(--space-xl)}.message-form{padding:var(--space-md) var(--space-xl)}}.legal-link-small{color:var(--text-muted);font-size:var(--font-size-xs);text-decoration:none;opacity:.7;transition:opacity var(--transition-fast),color var(--transition-fast);margin-top:var(--space-sm);display:inline-block;padding:var(--space-xs)}.legal-link-small:hover{opacity:1;color:var(--accent-primary);text-decoration:underline}.reply-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-top:1px solid rgba(255,255,255,.05);animation:slideUp .2s ease}.reply-banner.hidden{display:none}.reply-content{display:flex;gap:var(--space-sm);flex:1;overflow:hidden}.reply-line{width:4px;background:var(--accent-primary);border-radius:var(--radius-full)}.reply-info{display:flex;flex-direction:column;flex:1;overflow:hidden}.reply-to-text{font-size:var(--font-size-xs);color:var(--accent-primary);font-weight:600}.reply-to-text b{color:var(--text-primary)}.reply-pr.member-info{flex:1;min-width:0}.member-name-row{display:flex;align-items:center;gap:var(--space-xs)}.vibe-indicator{font-size:.9em;line-height:1;cursor:help;filter:drop-shadow(0 0 2px rgba(255,255,255,.3))}.member-name{font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-preview{font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-btn-small{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center}.icon-btn-small svg{width:16px;height:16px}.icon-btn-small:hover{background:#ffffff1a;color:var(--text-primary)}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.quoted-message{border-left:3px solid rgba(255,255,255,.3);background:#0003;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);margin-bottom:var(--space-xs);cursor:pointer;font-size:.85em;display:block}.message.sent .quoted-message{border-left-color:#ffffff80;background:#0000001a}.quoted-author{font-weight:600;color:var(--accent-primary);margin-bottom:2px;display:block}.message.sent .quoted-author{color:#ffffffe6}.quoted-text{color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.message.sent .quoted-text{color:#ffffffb3}.message{position:relative;transition:transform .2s cubic-bezier(.2,.8,.2,1);touch-action:pan-y;-webkit-user-select:none;user-select:none}.message.swiping{transition:none}.reply-btn-desktop{opacity:0;position:absolute;top:50%;transform:translateY(-50%);background:var(--bg-card);border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s ease,transform .1s ease;z-index:10;box-shadow:var(--shadow-sm)}.message:hover .reply-btn-desktop{opacity:1}.message.sent .reply-btn-desktop{left:-36px}.message.received .reply-btn-desktop{right:-36px}.reply-btn-desktop:hover{background:var(--bg-tertiary);color:var(--accent-primary);transform:translateY(-50%) scale(1.1)}@media(hover:none){.reply-btn-desktop{display:none}}.swipe-reply-icon{position:absolute;top:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:0;z-index:10;pointer-events:none;transform:translateY(-50%);transition:opacity .1s ease}.swipe-reply-icon svg{width:24px;height:24px;color:var(--text-secondary);transition:color .2s}@media(hover:hover){.desktop-hover-menu{position:absolute;top:-45px;left:0;right:auto;opacity:0;transform:translateY(10px) scale(.95);transition:all .2s cubic-bezier(.175,.885,.32,1.275);z-index:50;pointer-events:none;background:#1f2c34;border-radius:9999px;padding:6px 14px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #0006;border:1px solid rgba(255,255,255,.1)}.message:hover .desktop-hover-menu{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.message.sent .desktop-hover-menu{left:auto;right:0}.desktop-hover-menu .reaction-btn{font-size:24px;padding:2px}}@media(hover:none){.desktop-hover-menu{display:none!important}}.toolbar-separator{width:1px;height:16px;background:#ffffff1a;margin:0 4px}.reply-btn-desktop,.reaction-btn-desktop{display:none!important}.swipe-reply-icon.active svg{color:var(--accent-primary);transform:scale(1.2)}.reaction-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none}.reaction-menu{position:absolute;background:#1f2c34;border-radius:9999px;padding:8px 16px;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0006;z-index:1001;pointer-events:auto;animation:popIn .2s cubic-bezier(.175,.885,.32,1.275);border:1px solid rgba(255,255,255,.1)}.reaction-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:transparent;pointer-events:auto}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.reaction-list{display:flex;align-items:center;gap:8px}.reaction-btn{background:transparent;border:none;font-size:28px;cursor:pointer;padding:4px;transition:transform .2s;line-height:1;display:flex;align-items:center;justify-content:center}.reaction-btn:hover{transform:scale(1.3)}.reaction-btn:active{transform:scale(.95)}.reaction-btn-add{background:#ffffff1a;border:none;color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;margin-left:8px;transition:background .2s}.reaction-btn-reply{background:#ffffff1a;border:none;color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-left:4px;transition:background .2s,color .2s}.reaction-btn-reply:hover,.reaction-btn-add:hover{background:#fff3;color:#fff}.emoji-picker-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1002;box-shadow:var(--shadow-xl);border-radius:var(--radius-lg);overflow:hidden;width:90%;max-width:350px;background:var(--bg-card)}emoji-picker{width:100%;height:400px;--background: var(--bg-card);--border-color: rgba(255, 255, 255, .1)}.message-reactions{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.message.sent .message-reactions{justify-content:flex-end}.reaction-bubble{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2px 8px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:4px;color:var(--text-secondary);transition:transform .1s,background .2s,border-color .2s}.reaction-bubble:hover{background:var(--bg-tertiary);border-color:#fff3}.reaction-bubble.user-reacted{background:#667eea33;border-color:var(--accent-primary);color:var(--text-primary)}#hop-btn{position:relative;z-index:2;transition:all .3s ease}#hop-btn:before,#hop-btn:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;z-index:-1;pointer-events:none;border:1px solid var(--accent-primary);opacity:0}#hop-btn.scanning{color:var(--accent-primary)}#hop-btn.scanning:before{width:100%;height:100%;animation:hop-pulse-scan 3s cubic-bezier(0,0,.2,1) infinite}@keyframes hop-pulse-scan{0%{width:100%;height:100%;opacity:.5;border-width:1px}to{width:200%;height:200%;opacity:0;border-width:0px}}#hop-btn.intense{color:#4ade80!important;filter:drop-shadow(0 0 5px rgba(74,222,128,.5));animation:hop-shake .5s ease-in-out}#hop-btn.intense:before{width:100%;height:100%;border-color:#4ade80;animation:hop-pulse-intense 1.5s cubic-bezier(0,0,.2,1) infinite}#hop-btn.intense:after{width:100%;height:100%;border-color:#4ade80;animation:hop-pulse-intense 1.5s cubic-bezier(0,0,.2,1) infinite;animation-delay:.5s}@keyframes hop-pulse-intense{0%{width:100%;height:100%;opacity:.8;border-width:2px}to{width:250%;height:250%;opacity:0;border-width:0px}}@keyframes hop-shake{0%,to{transform:scale(1)}25%{transform:scale(1.1) rotate(5deg)}75%{transform:scale(1.1) rotate(-5deg)}}.logo-small{font-family:Major Mono Display,monospace;font-size:1.4rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-1px}.hop-btn.rainbow-pulse{background:linear-gradient(45deg,red,#ff7f00,#ff0,#0f0,#00f,indigo,#9400d3);background-size:200% 200%;animation:rainbow-pulse 2s ease infinite;box-shadow:0 0 15px #ffffff80;border:1px solid rgba(255,255,255,.8);color:#fff}@keyframes rainbow-pulse{0%{background-position:0% 50%;transform:scale(1);box-shadow:0 0 10px #ffffff4d}50%{background-position:100% 50%;transform:scale(1.1);box-shadow:0 0 25px #fff9}to{background-position:0% 50%;transform:scale(1);box-shadow:0 0 10px #ffffff4d}}.report-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.report-modal{background:var(--bg-secondary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);max-width:400px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.report-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid rgba(255,255,255,.1)}.report-modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:600}.report-close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.report-close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.report-modal-body{padding:var(--space-lg)}.report-preview{font-style:italic;color:var(--text-secondary);background:var(--bg-tertiary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:var(--font-size-sm);word-break:break-word}.report-instructions{margin-bottom:var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm)}.report-reasons{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.report-reason{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast)}.report-reason:hover{background:rgba(var(--bg-tertiary-rgb),.8)}.report-reason input[type=radio]{accent-color:var(--accent-primary)}.report-reason span{font-size:var(--font-size-sm)}.report-modal-body textarea{width:100%;min-height:80px;padding:var(--space-md);background:var(--bg-tertiary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-primary);font-family:inherit;font-size:var(--font-size-sm);resize:vertical}.report-modal-body textarea::placeholder{color:var(--text-muted)}.report-modal-body textarea:focus{outline:none;border-color:var(--accent-primary)}.report-modal-footer{display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-top:1px solid rgba(255,255,255,.1)}.report-cancel-btn{flex:1;padding:var(--space-sm) var(--space-md);background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.report-cancel-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.report-submit-btn{flex:1;padding:var(--space-sm) var(--space-md);background:var(--error);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.report-submit-btn:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.report-submit-btn:disabled{opacity:.7;cursor:not-allowed}.report-toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%) translateY(20px);background:var(--success);color:#fff;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);display:flex;align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-lg);opacity:0;transition:all var(--transition-normal);z-index:1001}.report-toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.report-toast-icon{font-size:18px;font-weight:700}.report-toast-text{font-size:var(--font-size-sm)}
