:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-tertiary: #e8e8e8;--color-text-primary: #1a1a1a;--color-text-secondary: #666666;--color-text-muted: #888;--color-text-placeholder: #bbb;--color-accent: #22c55e;--color-accent-rgb: 34, 197, 94;--color-accent-hover: #16a34a;--color-accent-light: #dcfce7;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-border: #e0e0e0;--color-shadow: rgba(0, 0, 0, .1);--color-bg-primary-rgb: 255, 255, 255;--color-bg-secondary-rgb: 245, 245, 245;--color-border-rgb: 224, 224, 224;--space-xxs: 2px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--letter-spacing-tight: -.02em;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 9999px;--top-header-height: 56px;--bottom-nav-height: 60px;--bottom-safe-area: max(4px, env(safe-area-inset-bottom, 0px));--bottom-nav-total-height: calc(var(--bottom-nav-height) + var(--bottom-safe-area));--max-width: 480px;--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-top: env(safe-area-inset-top, 0px);--backdrop-primary: blur(16px) saturate(120%);--backdrop-secondary: blur(8px) saturate(110%)}@media(prefers-color-scheme:dark){:root{--color-bg-primary: #0d1117;--color-bg-secondary: #161b22;--color-bg-tertiary: #21262d;--color-text-primary: #f0f6fc;--color-text-secondary: #8b949e;--color-text-muted: #8e96a1;--color-text-placeholder: #3e4651;--color-accent: #22c55e;--color-accent-rgb: 34, 197, 94;--color-accent-hover: #4ade80;--color-accent-light: #166534;--color-danger: #f87171;--color-danger-light: #7f1d1d;--color-border: #30363d;--color-shadow: rgba(0, 0, 0, .3);--color-bg-primary-rgb: 13, 17, 23;--color-bg-secondary-rgb: 22, 27, 34;--color-border-rgb: 48, 54, 61}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,body::-webkit-scrollbar{display:none}html{-webkit-text-size-adjust:100%;height:100%;margin:0;padding:0;background-color:var(--color-bg-secondary);overflow:hidden;overscroll-behavior:none}body{height:100%;margin:0;padding:0;overflow:hidden;overscroll-behavior:none;overflow-x:hidden;font-family:var(--font-sans);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:calc(100% + env(safe-area-inset-top));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none}#root{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--color-accent);text-decoration:none}@media(hover:hover){a:hover{color:var(--color-accent-hover)}}button{font-family:inherit;font-size:inherit;color:inherit;cursor:pointer;border:none;background:none}*:focus{outline:none}*{-webkit-tap-highlight-color:transparent}.selectable{user-select:text;-webkit-user-select:text}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full);border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],textarea,select{font-family:inherit;font-size:var(--font-size-md);background:transparent;border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding:var(--space-sm) 0;color:var(--color-text-primary);width:100%;transition:border-color .2s ease}textarea::placeholder,input::placeholder{color:var(--color-text-placeholder)}input:focus,textarea:focus,select:focus{outline:none;border-bottom-color:var(--color-accent)}input[type=time],input[type=date]{max-width:100%;background:transparent}input[type=range]{-webkit-appearance:none;appearance:none;width:calc(100% - 20px);height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none;margin:var(--space-sm) 10px;padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--color-accent);border-radius:var(--radius-full);cursor:pointer;border:none;box-shadow:0 2px 4px var(--color-shadow)}input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--color-accent);border-radius:var(--radius-full);cursor:pointer;border:none;box-shadow:0 2px 4px var(--color-shadow)}.form-group{margin-bottom:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs)}.form-group:last-child{margin-bottom:0}.form-label{display:flex;align-items:center;gap:6px;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:0}.form-error{color:var(--color-danger);font-size:var(--font-size-xs);margin-top:var(--space-xs)}.form-hint{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:var(--space-xs)}input.input-error,textarea.input-error{border-bottom-color:var(--color-danger)}input.input-error:focus,textarea.input-error:focus{border-bottom-color:var(--color-danger)}select{appearance:none;-webkit-appearance:none;background-color:transparent;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 0 center;padding-right:var(--space-lg);border:none;border-bottom:1px solid var(--color-border);border-radius:0;padding:var(--space-sm) 0;font-size:var(--font-size-md);color:var(--color-text-primary);width:100%}@media(prefers-color-scheme:dark){select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238b949e' d='M6 8L1 3h10z'/%3E%3C/svg%3E")}}.toggle-switch{display:inline-flex;align-items:center;gap:var(--space-sm);cursor:pointer}.toggle-switch--disabled{opacity:.5;cursor:not-allowed}.toggle-switch__track{position:relative;width:44px;height:24px;background:var(--color-bg-tertiary);border:none;border-radius:var(--radius-full);cursor:pointer;padding:0;transition:background-color .2s ease;flex-shrink:0}.toggle-switch__track:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.toggle-switch--on .toggle-switch__track{background:var(--color-accent)}.toggle-switch__knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:var(--radius-full);box-shadow:0 2px 4px #00000026;transition:transform .2s ease}.toggle-switch--on .toggle-switch__knob{transform:translate(20px)}.toggle-switch--disabled .toggle-switch__track{cursor:not-allowed}.toggle-switch__label{color:var(--color-text-primary);font-size:var(--font-size-md);-webkit-user-select:none;user-select:none}.layout-wrapper{min-height:100dvh;height:100%;display:flex;flex-direction:column;overflow:hidden}.container{max-width:var(--max-width);margin:0 auto;padding:var(--space-md);width:100%;overflow:visible}.auth-page{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--space-lg);padding-top:max(var(--space-lg),env(safe-area-inset-top));padding-bottom:max(var(--space-lg),env(safe-area-inset-bottom))}.auth-container{width:100%;max-width:var(--max-width)}.page{height:calc(100dvh - var(--bottom-nav-total-height));padding-top:max(var(--space-lg),env(safe-area-inset-top,0px));overflow-x:hidden}.page.no-header-offset{padding-top:env(safe-area-inset-top,0px)}.page-flex{display:flex;flex-direction:column;height:100%;min-width:0;overflow-x:hidden}.page-fixed{flex-shrink:0}.page-scroll{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;-webkit-overflow-scrolling:touch}.page-scroll:after{content:"";display:block;height:var(--space-md);flex-shrink:0}.top-header{position:fixed;top:0;left:0;right:0;height:calc(var(--top-header-height) + env(safe-area-inset-top));padding-top:env(safe-area-inset-top);background-color:var(--color-bg-primary);border-bottom:1px solid var(--color-border);z-index:1100}.top-header-content{display:flex;align-items:center;justify-content:space-between;height:var(--top-header-height);max-width:var(--max-width);margin:0 auto;padding:0 var(--space-md)}.top-header-title{font-size:var(--font-size-xl);font-weight:700;letter-spacing:var(--letter-spacing-tight);color:var(--color-text-primary)}.page.with-header{height:calc(100dvh - var(--bottom-nav-total-height) - var(--top-header-height) - env(safe-area-inset-top,0px));margin-top:calc(var(--top-header-height) + env(safe-area-inset-top));padding-top:0}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-total-height);padding-bottom:var(--bottom-safe-area);background:rgba(var(--color-bg-primary-rgb),.85);backdrop-filter:var(--backdrop-primary);-webkit-backdrop-filter:var(--backdrop-primary);border-top:1px solid rgba(var(--color-border-rgb),.5);z-index:1000}.bottom-nav-content{display:flex;justify-content:space-around;align-items:center;height:100%;width:100%;max-width:var(--max-width);margin:0 auto}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--space-sm);min-width:60px;color:var(--color-text-muted);transition:color .2s ease,transform .2s cubic-bezier(.34,1.56,.64,1);text-decoration:none}.bottom-nav-item:active{transform:scale(.92)}.bottom-nav-item.active{color:var(--color-accent)}.bottom-nav-item svg{width:24px;height:24px;flex-shrink:0;max-height:100%}.bottom-nav-label{font-size:var(--font-size-xs)}@media(max-width:360px){.bottom-nav-item{padding:var(--space-xs);min-width:50px}.bottom-nav-item svg{width:20px;height:20px}.bottom-nav-label{font-size:.65rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:600;transition:all .2s cubic-bezier(.34,1.56,.64,1);touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer}.btn:active{transform:scale(.97)}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-outline{background-color:transparent;border:1px solid var(--color-accent);color:var(--color-accent)}.btn-danger-outline{background-color:transparent;border:1px solid var(--color-danger);color:var(--color-danger)}.btn-danger{background-color:var(--color-danger);color:#fff}@media(hover:hover){.btn-primary:hover{background-color:var(--color-accent-hover);color:#fff;box-shadow:0 4px 14px #10b98159}.btn-secondary:hover{background-color:var(--color-border)}.btn-outline:hover{background-color:var(--color-accent-light)}.btn-danger-outline:hover{background-color:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-icon-close{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);background-color:var(--color-bg-tertiary);transition:all .2s ease}.btn-icon-close:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.btn-choice{flex:1;height:36px;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;white-space:nowrap;user-select:none;-webkit-user-select:none}.btn-choice:active{transform:scale(.96)}.btn-accept{background:transparent;border:2px solid var(--color-accent);color:var(--color-accent)}.btn-accept.selected{background:var(--color-accent);color:var(--color-bg-primary);flex:10}.btn-decline{background:transparent;border:2px solid var(--color-danger);color:var(--color-danger)}.btn-decline.selected{background:var(--color-danger);color:#fff;flex:10}@media(hover:hover){.btn-accept:not(.selected):hover:not(:disabled){background:#4ade801a}.btn-accept.selected:hover{filter:brightness(.95)}.btn-decline:not(.selected):hover:not(:disabled){background:#ef44441a}.btn-decline.selected:hover{filter:brightness(.95)}}.btn-choice.is-hidden{flex:0;width:0;min-width:0;padding:0;margin:0;border-width:0;opacity:0;pointer-events:none}.btn-confirmation-text{font-size:var(--font-size-sm);opacity:.7;font-weight:400}.btn-leave{background:transparent;border:1px solid var(--color-border);color:var(--color-danger)}.btn-back{background:transparent;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-icon-square{width:36px;height:36px;min-width:36px;min-height:36px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s ease}.btn-icon-square:active:not(:disabled){transform:scale(.92)}.btn-icon-square svg{flex-shrink:0}.btn-icon{height:32px;min-height:32px;padding:0 var(--space-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.btn-icon svg{flex-shrink:0}.avatar{position:relative;width:40px;height:40px;border-radius:var(--radius-full);background-color:var(--color-accent-light);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--color-accent);flex-shrink:0;box-shadow:inset 0 0 0 1px #0000000f}.avatar:before{content:"";position:absolute;inset:0;border-radius:var(--radius-full);overflow:hidden;pointer-events:none}.avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-full)}.avatar-xs{width:24px;height:24px;font-size:var(--font-size-xs)}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-sm)}.avatar-lg{width:64px;height:64px;font-size:var(--font-size-xl)}.avatar-xl{width:96px;height:96px;font-size:var(--font-size-2xl)}.avatar-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:50%}.avatar-image-loading{opacity:0;transition:opacity .3s ease}.avatar-image-loaded{opacity:1;transition:opacity .3s ease}.avatar-ready{border:2px solid #22c55e!important;box-sizing:border-box;--avatar-status-glow-min: 0 0 6px 1px rgba(34, 197, 94, .55);--avatar-status-glow-max: 0 0 12px 3px rgba(34, 197, 94, .75);animation:avatar-status-pulse 1.5s ease-in-out infinite}.avatar-scheduled,.avatar-stack--muted .avatar.avatar-scheduled{border:2px solid #9ca3af!important;box-sizing:border-box;animation:none}@keyframes avatar-status-pulse{0%,to{box-shadow:var(--avatar-status-glow-min)}50%{box-shadow:var(--avatar-status-glow-max)}}.avatar-edit-overlay{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-secondary);border:2px solid var(--color-bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,background-color .2s ease;padding:0;z-index:1;box-shadow:0 2px 4px #00000026}.avatar-edit-overlay:hover{background:var(--color-border);transform:scale(1.1)}.avatar-edit-overlay:active{transform:scale(.95)}.avatar-stack{display:flex;align-items:center;overflow:visible}.avatar-stack .avatar{margin-left:-10px;border:2px solid var(--color-bg-primary)}.avatar-stack .avatar:first-child{margin-left:0}.avatar-stacked{margin-left:-10px;border:2px solid var(--color-bg-primary)}.avatar-stacked:first-child{margin-left:0}.avatar-more{font-size:var(--font-size-xs);background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.avatar-stack--muted .avatar{opacity:.6;filter:grayscale(40%)}.avatar-accepted{box-shadow:0 0 0 2px var(--color-accent)}.avatar-declined{box-shadow:0 0 0 2px var(--color-danger)}.group-avatar{position:relative;display:inline-flex;border-radius:var(--radius-full);overflow:visible}.group-avatar--scheduled>.avatar{box-shadow:0 0 0 2px var(--group-ring-color, var(--color-text-muted));animation:none}.group-avatar--ready>.avatar{box-shadow:0 0 0 2px var(--group-ring-color, var(--color-accent)),0 0 8px 2px var(--group-ring-color, var(--color-accent));animation:group-ring-pulse 1.5s ease-in-out infinite}@keyframes group-ring-pulse{0%,to{box-shadow:0 0 0 2px var(--group-ring-color, var(--color-accent)),0 0 8px 2px var(--group-ring-color, var(--color-accent))}50%{box-shadow:0 0 0 2px var(--group-ring-color, var(--color-accent)),0 0 14px 4px var(--group-ring-color, var(--color-accent))}}.group-avatar-stack{display:flex;align-items:center;overflow:visible;padding:4px;margin:-4px}.group-avatar-stack>.group-avatar{margin-left:-8px}.group-avatar-stack>.group-avatar:first-child{margin-left:0}.group-avatar-stack>.group-avatar>.avatar{border:2px solid var(--color-bg-primary)}.context-greeter{display:flex;flex-direction:column;position:relative;width:100%;gap:4px;padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.context-greeter__mode-line{display:flex;align-items:flex-start;gap:6px}.context-greeter__mode-icon{width:22px;height:22px;margin-top:10px;border-radius:999px;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 2px var(--color-shadow)}.context-greeter__mode-row{display:flex;gap:var(--space-sm);min-width:0;flex:1;overflow-x:auto;padding-bottom:1px;padding-right:30px;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;-webkit-overflow-scrolling:touch}.context-greeter__mode-row--flat{padding-top:2px}.context-greeter__mode-row::-webkit-scrollbar{height:4px}.context-greeter__mode-row::-webkit-scrollbar-track{background:transparent}.context-greeter__mode-row::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.context-greeter__item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);flex-shrink:0}.context-greeter__item--active .context-greeter__pill{background:var(--color-bg-tertiary)}.context-greeter__item--active .context-greeter__label{font-weight:600}.context-greeter__pill{display:flex;align-items:center;height:44px;padding:2px 2px 2px 10px;padding-right:var(--space-xs);border-radius:99px;border:2px solid transparent;background:transparent;transition:border-color .2s ease,background-color .2s ease;min-width:60px;justify-content:center}.context-greeter__view-toggle{position:absolute;top:var(--space-sm);right:0;width:24px;height:24px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-secondary);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:2}.context-greeter__view-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.context-greeter__emoji-btn{border:none;background:transparent;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;line-height:1}.context-greeter__emoji-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-full)}.context-greeter__emoji{font-size:1.25rem;line-height:1}.context-greeter__avatars{display:flex;align-items:center;margin-left:10px}.context-greeter__avatar-wrapper{position:relative;border-radius:50%;box-shadow:0 0 0 2px var(--color-bg-primary);cursor:pointer}.context-greeter__more-count{font-size:11px;font-weight:600;color:var(--color-text-secondary);background:var(--color-bg-tertiary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-left:-10px;border:2px solid var(--color-bg-primary)}.context-greeter__empty-dash{margin-left:12px;font-weight:700;color:var(--color-text-muted);opacity:.5}.context-greeter__label{font-size:11px;color:var(--color-text-secondary);font-weight:500;max-width:96px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center}.context-greeter__empty{width:100%;text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.badge-accent{background-color:var(--color-accent-light);color:var(--color-accent)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger)}.badge-lg{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.alert{padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.alert-warning{background-color:#fef3c7;color:#92400e;border:1px solid #fcd34d}.alert-error{background-color:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger)}.alert-success{background-color:var(--color-accent-light);color:var(--color-accent);border:1px solid var(--color-accent)}.loading-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:var(--radius-full);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.spinner-small{width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:var(--radius-full);animation:spin .8s linear infinite}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:var(--space-md);padding-top:max(var(--space-lg),var(--safe-area-inset-top));padding-bottom:max(var(--space-lg),var(--safe-area-inset-bottom));overflow-y:auto}.modal{background-color:var(--color-bg-primary);border-radius:var(--radius-xl);max-width:400px;width:100%;max-height:calc(100vh - var(--space-2xl));display:flex;flex-direction:column}.modal-scrollable{max-height:calc(100vh - var(--space-xl))}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);padding-bottom:0;flex-shrink:0}.modal-title{font-size:var(--font-size-xl);font-weight:600}.modal-close{color:var(--color-text-muted);padding:var(--space-xs)}.modal-close:hover{color:var(--color-text-primary)}.modal-body{flex:1;overflow-y:auto;padding:var(--space-lg);-webkit-overflow-scrolling:touch}.modal-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg)}.modal-actions .btn{flex:1}.confirm-modal{max-width:340px;padding:0}.confirm-modal__header{padding:var(--space-lg);padding-bottom:var(--space-sm)}.confirm-modal__title{font-size:var(--font-size-lg);font-weight:600;margin:0}.confirm-modal__body{padding:0 var(--space-lg);padding-bottom:var(--space-lg)}.confirm-modal__message{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5}.confirm-modal__actions{display:flex;gap:var(--space-sm);padding:var(--space-md) var(--space-md);border-top:1px solid var(--color-border)}.confirm-modal__actions .btn{flex:1}.time-picker-modal{width:280px;max-width:90vw}.time-picker-modal .modal-body{padding:0}.time-picker-modal .modal-footer{display:flex;gap:var(--space-sm);padding:var(--space-md);background-color:var(--color-bg-primary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.time-picker-modal .modal-footer .btn{flex:1}.modal-compact{max-width:360px}.modal-compact .modal-header{padding:var(--space-md) var(--space-md) 0 var(--space-md)}.modal-compact .modal-title{font-size:var(--font-size-lg)}.modal-compact .modal-body{padding:var(--space-md)}.wheel-container{mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 15%,black 85%,transparent 100%)}.wheel-item{--item-y: calc(var(--item-index) * 32px);--relative-y: calc(var(--item-y) - var(--scroll-top));--angle-deg: calc(var(--relative-y) / 32 * 35);transform:perspective(500px) rotateX(calc(var(--angle-deg) * -1deg)) scale(max(.85,calc(1 - abs(var(--relative-y) / 256))));opacity:max(.1,calc(1 - abs(var(--relative-y) / 48)));color:var(--color-text-muted)}.selection-overlay{position:absolute;top:50%;left:var(--space-xs);right:var(--space-xs);height:28px;transform:translateY(-50%);backdrop-filter:brightness(2) contrast(1) drop-shadow(0 1px 1px rgba(0,0,0,.3));-webkit-backdrop-filter:brightness(2) contrast(1) drop-shadow(0 1px 1px rgba(0,0,0,.3));border-radius:var(--radius-sm);pointer-events:none;z-index:1}@media(prefers-color-scheme:light){.selection-overlay{backdrop-filter:brightness(.7) contrast(2) drop-shadow(0 1px 1px rgba(0,0,0,.3));-webkit-backdrop-filter:brightness(.7) contrast(2) drop-shadow(0 1px 1px rgba(0,0,0,.3))}}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{scrollbar-width:none}.friend-info-popup-overlay{position:fixed;inset:0;background:#0000004d;z-index:9998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.friend-info-popup{position:fixed;z-index:9999;animation:popupSlideIn .2s ease-out;max-width:90vw}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;bottom:calc(var(--bottom-nav-total-height) + var(--space-md));left:var(--space-md);right:var(--space-md);z-index:1000}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--color-text-secondary)}.empty-state-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.6;animation:emptyStatePulse 2s ease-in-out infinite;width:64px;height:64px;display:flex;align-items:center;justify-content:center}@keyframes emptyStatePulse{0%,to{transform:scale(1);opacity:.6}50%{transform:scale(1.05);opacity:.8}}.empty-state-title{font-weight:600;font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--space-xs)}.empty-state-text{font-size:var(--font-size-sm);max-width:280px;line-height:1.5;margin-bottom:var(--space-lg)}.empty-state .btn{margin-top:var(--space-sm)}.list{display:flex;flex-direction:column}.list-item,.card{padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:0 3px 10px #0000001a,inset 0 0 0 1px #ffffff1a}.profile-card{width:100%}.list-item{display:flex;align-items:center;gap:var(--space-md);position:relative;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease}.list-item:active{transform:translateY(0)}.list-item-new{border-left:4px solid var(--color-accent);padding-left:calc(var(--space-md) - 4px)}.archived-group-item{opacity:.7}@media(hover:hover){.list-item:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.list-item:hover,.list-item-interactive:hover{background-color:var(--color-bg-secondary)}}.list-item-content{flex:1;min-width:0}.list-item-title{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item-actions{display:flex;gap:var(--space-sm)}.list-item-interactive{cursor:pointer}.section-header{font-size:var(--font-size-lg);margin-bottom:var(--space-md);margin-top:var(--space-xl)}.section-header:first-of-type{margin-top:0}.text-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-input-wrapper{position:relative;flex:1}.search-clear-btn{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);background:var(--color-bg-secondary);border:none;border-radius:var(--radius-full);width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0}.search-clear-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.swipeable-content{background-color:var(--color-bg-primary);transition:background-color .2s ease}@media(hover:hover){.list-item:hover .swipeable-content,.list-item-interactive:hover .swipeable-content{background-color:var(--color-bg-secondary)}}.unified-list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-xs);position:relative;margin-bottom:0;cursor:pointer;transition:background-color .2s ease}.unified-list-item--last{margin-bottom:0}.unified-list-item:after{content:"";position:absolute;bottom:0;left:var(--space-md);right:var(--space-md);height:1px;background:var(--color-border);pointer-events:none;z-index:1}.unified-list-item:last-child:after,.unified-list-item--last:after{display:none}.unified-list-item__content{display:flex;justify-content:space-between;align-items:center;padding:calc(var(--space-xs) + 2px) var(--space-md);gap:var(--space-sm)}.unified-list-item__text{flex:1;min-width:0;overflow:hidden}.unified-list-item__primary{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:var(--space-xs)}.unified-list-item__secondary{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unified-list-item__actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.group-list-item__content{display:flex;justify-content:space-between;align-items:center;padding:calc(var(--space-xs) + 2px) var(--space-md);gap:var(--space-sm);width:100%;overflow:visible}.group-list-item__text{flex:1;min-width:0;overflow:hidden;margin-right:var(--space-sm);display:flex;flex-direction:column;align-items:flex-start}.group-list-item__time{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:var(--space-xs);max-width:100%}.group-list-item__place{font-size:var(--font-size-sm);color:var(--color-text-muted);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:left}.group-list-item--changed{border-left:3px solid var(--group-color, var(--color-accent))}.group-list-item__emoji{flex-shrink:0;font-size:1.5rem;line-height:1;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:2px solid var(--color-border);overflow:hidden}.group-list-item__emoji-image{width:70%;height:70%;display:block;object-fit:contain}.group-list-item__emoji-image--legacy{width:90%;height:90%}.group-new-badge{font-size:var(--font-size-xs);padding:2px 6px;border-radius:var(--radius-sm);background-color:var(--group-color, var(--color-accent));color:#fff;font-weight:500;flex-shrink:0;line-height:1.2}.group-list-item__indicators{display:inline-flex;align-items:center;gap:var(--space-xs);flex-shrink:0}.friend-list-item__content{display:flex;justify-content:space-between;align-items:center;padding:calc(var(--space-xs) + 2px) var(--space-md);gap:var(--space-md);width:100%;overflow:visible}.friend-list-item__avatar{flex-shrink:0}.friend-list-item__info{flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;align-items:flex-start}.friend-list-item__name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-list-item__username{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-list-item__actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.swipeable-list-item{position:relative;overflow:hidden}.list-item-all-accepted{border:2px solid var(--color-accent);box-shadow:0 0 8px #4ade8033}.list-item-unread-badge{width:10px;height:10px;border-radius:var(--radius-full);background-color:var(--color-accent);flex-shrink:0}.group-unread-icon{flex-shrink:0}.floating-save-btn-container{position:fixed;bottom:var(--bottom-nav-total-height);left:0;right:0;padding:0 var(--space-md) var(--space-md);max-width:var(--max-width);margin:0 auto;z-index:999;pointer-events:none}.floating-save-btn-container:before{content:"";position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(to top,var(--color-bg-primary) 60%,transparent 100%);pointer-events:none}.floating-save-btn{position:relative;width:100%;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);border:none;font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #0000004d;pointer-events:auto;display:block;background-color:var(--color-bg-tertiary);color:var(--color-text-muted)}.floating-save-btn:disabled{cursor:not-allowed;opacity:.6}.floating-save-btn.active{background-color:var(--color-accent);color:#fff}.floating-save-btn.active:hover:not(:disabled){filter:brightness(1.1)}.notification-bell-container{position:relative;z-index:1950}.notification-bell{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);backdrop-filter:var(--backdrop-secondary);-webkit-backdrop-filter:var(--backdrop-secondary);color:var(--color-text-secondary);transition:background-color .2s ease,color .2s ease,border-color .2s ease;cursor:pointer}.notification-bell:hover{color:var(--color-text-primary);border-color:color-mix(in srgb,var(--color-accent) 35%,var(--color-border));background:rgba(var(--color-bg-primary-rgb),.8)}.notification-bell.is-open{color:var(--color-accent);border-color:color-mix(in srgb,var(--color-accent) 55%,var(--color-border));background:rgba(var(--color-bg-primary-rgb),.85)}.notification-bell svg{width:21px;height:21px}.notification-bell-badge{position:absolute;top:0;right:0;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 0 0 2px var(--color-bg-primary)}.notification-panel-backdrop{position:fixed;inset:0;z-index:1900;border:none;background:#00000042;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);cursor:default}.notification-panel{position:absolute;top:calc(100% + var(--space-sm));right:0;z-index:1951;width:min(360px,calc(100vw - var(--space-lg)));max-height:min(72vh,480px);display:flex;flex-direction:column;border-radius:var(--radius-xl);border:1px solid rgba(var(--color-border-rgb),.7);background:linear-gradient(180deg,rgba(var(--color-bg-primary-rgb),.92),rgba(var(--color-bg-secondary-rgb),.9));backdrop-filter:var(--backdrop-primary);-webkit-backdrop-filter:var(--backdrop-primary);box-shadow:0 18px 42px #0003;overflow:hidden;animation:notificationPanelIn .16s ease-out}@keyframes notificationPanelIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid rgba(var(--color-border-rgb),.55);flex-shrink:0}.notification-panel-title-wrap{display:inline-flex;align-items:center;gap:var(--space-xs);min-width:0}.notification-panel-title-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.notification-panel-title{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.notification-panel-unread-pill{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-accent) 20%,transparent);color:var(--color-accent);font-size:11px;font-weight:700}.notification-panel-action{border:1px solid rgba(var(--color-border-rgb),.7);border-radius:var(--radius-full);background:rgba(var(--color-bg-primary-rgb),.7);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;line-height:1;padding:6px 10px;cursor:pointer;transition:color .2s ease,border-color .2s ease,background-color .2s ease}.notification-panel-action:hover:not(:disabled){color:var(--color-text-primary);border-color:color-mix(in srgb,var(--color-accent) 35%,var(--color-border));background:rgba(var(--color-bg-primary-rgb),.92)}.notification-panel-action:disabled{opacity:.45;cursor:not-allowed}.notification-panel-content{overflow-y:auto;max-height:inherit;-webkit-overflow-scrolling:touch}.notification-empty{padding:var(--space-xl);color:var(--color-text-muted);text-align:center}.notification-item{--notification-item-accent: var(--color-accent);width:100%;border:none;background:transparent;color:inherit;display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;text-align:left;border-bottom:1px solid rgba(var(--color-border-rgb),.4);transition:background-color .2s ease}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:color-mix(in srgb,var(--notification-item-accent) 7%,transparent)}.notification-item.unread{background:color-mix(in srgb,var(--notification-item-accent) 11%,transparent)}.notification-item.unread:hover{background:color-mix(in srgb,var(--notification-item-accent) 14%,transparent)}.notification-item-icon{width:34px;height:34px;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;color:var(--notification-item-accent);background:color-mix(in srgb,var(--notification-item-accent) 14%,var(--color-bg-secondary));border:1px solid color-mix(in srgb,var(--notification-item-accent) 28%,var(--color-border));flex-shrink:0}.notification-leading-emoji{font-size:16px;line-height:1}.notification-leading-default-logo{width:18px;height:18px;display:block;object-fit:contain}.notification-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notification-item-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-sm)}.notification-item-title{font-size:var(--font-size-sm);font-weight:650;color:var(--color-text-primary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.notification-item-time{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.notification-item-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:1px}.notification-chip{--notification-group-color: var(--color-accent);display:inline-flex;align-items:center;gap:4px;max-width:100%;border-radius:var(--radius-full);border:1px solid rgba(var(--color-border-rgb),.7);background:rgba(var(--color-bg-primary-rgb),.72);color:var(--color-text-secondary);font-size:11px;font-weight:600;line-height:1;padding:3px 7px}.notification-chip--compact{font-size:10px;padding:3px 6px}.notification-chip--group{border-color:color-mix(in srgb,var(--notification-group-color) 38%,var(--color-border));background:color-mix(in srgb,var(--notification-group-color) 14%,var(--color-bg-secondary));color:color-mix(in srgb,var(--notification-group-color) 76%,var(--color-text-primary))}.notification-chip-leading,.notification-chip-trailing{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.notification-chip-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.notification-chip-avatar.avatar.avatar-xs{width:18px;height:18px;font-size:10px}.notification-chip-emoji{line-height:1}.notification-chip-default-logo{width:12px;height:12px;display:block}.notification-item-body{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.35;margin-top:1px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--notification-item-accent);flex-shrink:0;margin-top:5px}.notification-banner{--notification-banner-accent: var(--color-accent);position:fixed;top:0;left:0;right:0;z-index:2050;pointer-events:none;padding:calc(env(safe-area-inset-top) + var(--space-sm)) var(--space-md) 0}.notification-banner--enter .notification-banner__card{animation:notificationBannerIn .28s cubic-bezier(.2,.8,.2,1)}@keyframes notificationBannerIn{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}.notification-banner__card{pointer-events:auto;max-width:var(--max-width);margin:0 auto;display:flex;align-items:flex-start;gap:var(--space-sm);border-radius:var(--radius-xl);border:1px solid rgba(var(--color-border-rgb),.7);background:linear-gradient(180deg,rgba(var(--color-bg-primary-rgb),.92),rgba(var(--color-bg-secondary-rgb),.88));backdrop-filter:var(--backdrop-primary);-webkit-backdrop-filter:var(--backdrop-primary);box-shadow:0 14px 36px #0003;padding:var(--space-sm) var(--space-md);cursor:pointer;transition:transform .2s ease-out,opacity .2s ease-out}.notification-banner__card.is-swiping{transition:none}.notification-banner__icon{width:30px;height:30px;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;color:var(--notification-banner-accent);background:color-mix(in srgb,var(--notification-banner-accent) 14%,var(--color-bg-secondary));border:1px solid color-mix(in srgb,var(--notification-banner-accent) 30%,var(--color-border));flex-shrink:0}.notification-banner__icon .notification-leading-emoji{font-size:17px}.notification-banner__content{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}.notification-banner__title-row{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-sm)}.notification-banner__title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-banner__time{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0}.notification-banner__body{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-banner__meta{margin-top:2px;display:flex;align-items:center;gap:6px}.notification-banner__paused{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0;padding-top:2px}.nav-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.nav-badge{position:absolute;top:-4px;right:-6px;min-width:12px;height:12px;padding:0 3px;border-radius:var(--radius-full);background-color:var(--color-danger);color:#fff;font-size:8px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}.nav-badge-dot{position:absolute;top:-4px;right:-6px;width:12px;height:12px;border-radius:var(--radius-full);background-color:var(--color-danger)}@media(max-width:480px){.notification-panel{right:calc(var(--space-xs) * -1)}}.context-menu-overlay{position:fixed;inset:0;z-index:2000;background:#0000004d;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.context-menu{position:fixed;min-width:180px;max-width:260px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:0 8px 32px #0003;overflow:hidden;animation:contextMenuIn .15s ease-out}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-emojis{display:flex;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);justify-content:center}.context-menu-emoji{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:20px;background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all .15s}.context-menu-emoji:hover{background:var(--color-bg-secondary);transform:scale(1.15)}.context-menu-emoji:active{transform:scale(.95)}.context-menu-emoji-plus{font-size:18px;font-weight:300;color:var(--color-text-muted);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1.5px dashed var(--color-text-muted);border-radius:var(--radius-sm);opacity:.6;transition:opacity .15s,border-color .15s}.context-menu-emoji-plus:hover{opacity:1;border-color:var(--color-text-secondary)}.context-menu-actions{padding:var(--space-xs) 0}.context-menu-action{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-sm) var(--space-lg);background:transparent;border:none;font-size:var(--font-size-md);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background .15s}.context-menu-action:hover{background:var(--color-bg-secondary)}.context-menu-action svg{flex-shrink:0;color:var(--color-text-muted)}.context-menu-action-danger{color:var(--color-danger)}.context-menu-action-danger svg{color:var(--color-danger)}.location-input-wrapper{display:flex;gap:var(--space-xs);align-items:stretch}.location-input-field{flex:1;min-width:0}.location-input-buttons{display:flex;gap:var(--space-xs);flex-shrink:0}.location-input-btn{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.location-input-btn:hover:not(:disabled){background:var(--color-accent-light);border-color:var(--color-accent);color:var(--color-accent)}.location-input-btn:disabled{opacity:.5;cursor:not-allowed}.location-input-btn svg{width:20px;height:20px}.address-suggestions{position:absolute;left:0;right:0;bottom:100%;margin-bottom:var(--space-xs);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 -4px 16px #00000026;max-height:200px;overflow-y:auto;z-index:1001}.address-suggestion-item{padding:var(--space-sm) var(--space-md);cursor:pointer;font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.address-suggestion-item:last-child{border-bottom:none}.address-suggestion-item:hover,.address-suggestion-item.selected{background:var(--color-bg-tertiary)}.modal-fullscreen{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden}@media(min-width:768px){.modal-fullscreen{width:90%;height:90%;max-width:800px;max-height:600px;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000040}}.map-picker-container{flex:1;min-height:0;position:relative}.map-picker-footer{flex-shrink:0;padding:var(--space-md);border-top:1px solid var(--color-border);background:var(--color-bg-primary);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.walk-status-card{padding:var(--space-md) var(--space-md);min-height:100px;transition:all .3s ease;display:flex;flex-direction:column;justify-content:center}.walk-status-card .flex.flex-col{gap:var(--space-xs)}.walk-status-card .walk-location-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.walk-status-actions{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center}.walk-status-actions .btn{flex:1 0 125px;max-width:150px}.walk-status-card.walk-ready-active{background-color:var(--color-bg-primary);border-color:var(--color-accent);display:flex;align-items:center;animation:card-pulse 2s infinite;border:2px solid var(--color-accent);box-shadow:0 4px 12px var(--color-accent-light)}.walk-status-card.walk-scheduled-active{background-color:var(--color-bg-primary);border:2px solid var(--color-text-muted);box-shadow:none;animation:none}@keyframes card-pulse{0%{box-shadow:0 0 #22c55e66}70%{box-shadow:0 0 0 6px #22c55e00}to{box-shadow:0 0 #22c55e00}}.timeline-widget{padding:var(--space-sm) 4px;margin-bottom:var(--space-lg);overflow:visible;position:relative;border-radius:12px}.timeline-header-row{display:flex;align-items:flex-end;position:relative;height:16px;margin-bottom:4px}.timeline-header-left{width:20px;display:flex;justify-content:center;align-items:flex-end;flex-shrink:0;position:relative;z-index:2}.timeline-header-right{width:32px;display:flex;justify-content:center;align-items:flex-end;flex-shrink:0;position:relative;z-index:2}.timeline-header-center{flex:1;position:relative;height:100%}.timeline-header-icon--friends{color:var(--color-accent);height:16px}.timeline-header-icon--rain{color:#3b82f6;height:16px}.timeline-sun-icon{position:absolute;bottom:0;transform:translate(-50%);opacity:.5;height:16px;z-index:0}.timeline-now-label{position:absolute;transform:translate(-50%);font-size:10px;font-weight:700;color:var(--color-accent);padding:2px 4px;border-radius:4px;z-index:1}.timeline-popup{position:absolute;top:24px;transform:translate(-50%,-100%);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 4px 15px #0009;z-index:100;display:flex;flex-direction:row;height:96px;width:max-content;padding:8px 12px;gap:0;pointer-events:none}.timeline-popup__left{display:flex;flex-direction:column;align-items:center;gap:8px;width:24px;padding-right:4px;border-right:1px solid var(--color-border)}.timeline-popup__content{display:flex;flex-direction:column;gap:8px;padding-left:8px;flex:1}.timeline-popup__line{display:flex;align-items:center;gap:8px;font-size:13px;line-height:1.1;white-space:nowrap;height:20px}.timeline-popup__left .timeline-popup__line:first-child,.timeline-popup__content .timeline-popup__line:first-child{height:30px}.timeline-popup__emoji{font-size:14px}.timeline-popup__time{font-weight:700;color:#fff;font-size:11px}.timeline-popup__friends{font-weight:700;color:var(--color-accent);font-size:14px}.timeline-popup__weather{font-size:11px;color:var(--color-text-muted)}.timeline-popup__temp{font-weight:500}.timeline-popup__rain{color:#3b82f6}.avatar-stack--popup{margin-left:0;display:flex;height:28px;align-items:center}.avatar-stack--popup .avatar-stacked{margin-left:-8px;border:2px solid var(--color-bg-primary)}.timeline-yaxis-overlay{position:relative;height:60px;margin-bottom:-60px;z-index:5;pointer-events:none}.timeline-yaxis--left{position:absolute;left:0;width:20px;height:100%}.timeline-yaxis--right{position:absolute;right:0;width:32px;height:100%}.timeline-yaxis-label{position:absolute;width:100%;text-align:center;transform:translateY(-50%);font-size:10px;color:var(--color-text-muted)}.timeline-chart{width:100%;display:block;cursor:crosshair}.timeline-weather-row{display:flex;position:relative;height:20px;margin-top:4px;padding:0 32px 0 20px}.timeline-weather-item{position:absolute;transform:translate(-50%);display:flex;align-items:center;gap:4px;font-size:12px;font-weight:700}.timeline-weather-temp{color:var(--color-text-muted)}.timeline-divider{height:1px;background:var(--color-border);margin:4px 32px 4px 20px}.timeline-hours-row{display:flex;position:relative;height:14px;padding:0 32px 0 20px}.timeline-hours-row--no-weather{margin-top:12px}.timeline-hour-label{position:absolute;transform:translate(-50%);font-size:12px;font-weight:700;color:var(--color-text-muted)}.timeline-unit-label{position:absolute;left:-9px;width:22px;text-align:right;top:50%;transform:translateY(-50%);font-size:10px;font-weight:700;color:var(--color-text-muted);opacity:.6}.invite-card{--invite-group-color: var(--color-accent);cursor:default}.invite-card__content{width:auto;flex:1;min-width:0;padding-left:var(--space-md);padding-right:var(--space-md);gap:var(--space-sm)}.invite-card__source{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.invite-card__source-emoji{border-color:color-mix(in srgb,var(--invite-group-color) 45%,var(--color-border));background:color-mix(in srgb,var(--invite-group-color) 12%,transparent)}.invite-card__source-text{display:flex;flex-direction:column;gap:1px;min-width:0}.invite-card__title-line{display:flex;align-items:center;gap:6px;min-width:0}.invite-card__source-name{font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-card__source-from{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.invite-card__actions{gap:6px;margin-left:auto;flex-shrink:0}.invite-list-badge{background:var(--color-accent);color:var(--color-bg-primary);font-size:10px;font-weight:700;padding:2px 7px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.4px;width:fit-content}.invite-list-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--color-border);cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;transition:transform .15s ease,background-color .2s ease,border-color .2s ease}.invite-list-btn:active:not(:disabled){transform:scale(.95)}.invite-list-btn:disabled{opacity:.5;cursor:not-allowed}.invite-list-btn--info{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-secondary)}.invite-list-btn--info:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:color-mix(in srgb,var(--invite-group-color) 35%,var(--color-border));color:var(--color-text-primary)}.invite-list-btn--accept{background:color-mix(in srgb,var(--invite-group-color) 22%,var(--color-bg-secondary));border-color:color-mix(in srgb,var(--invite-group-color) 44%,var(--color-border));color:var(--color-text-primary)}.invite-list-btn--accept:hover:not(:disabled){background:color-mix(in srgb,var(--invite-group-color) 32%,var(--color-bg-secondary))}.invite-list-btn--decline{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-secondary)}.invite-list-btn--decline:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.group-mode-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;line-height:1;padding:3px 7px;border-radius:var(--radius-full);border:1px solid var(--color-border);color:var(--color-text-secondary);background:var(--color-bg-secondary);white-space:nowrap}.group-mode-badge svg{flex-shrink:0}.group-mode-badge--compact{font-size:9px;padding:2px 6px}.group-mode-badge--map{background:color-mix(in srgb,#3b82f6 14%,var(--color-bg-secondary));border-color:color-mix(in srgb,#3b82f6 32%,var(--color-border));color:color-mix(in srgb,#3b82f6 80%,var(--color-text-primary))}.group-mode-badge--categorical{background:color-mix(in srgb,#f59e0b 16%,var(--color-bg-secondary));border-color:color-mix(in srgb,#f59e0b 34%,var(--color-border));color:color-mix(in srgb,#b45309 76%,var(--color-text-primary))}.group-mode-badge--status{background:color-mix(in srgb,#14b8a6 16%,var(--color-bg-secondary));border-color:color-mix(in srgb,#14b8a6 34%,var(--color-border));color:color-mix(in srgb,#0f766e 76%,var(--color-text-primary))}.invite-info-modal__source{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.invite-info-modal__source .invite-card__source-emoji{width:30px;height:30px;font-size:1rem;border-radius:9px;border-width:1px}.invite-info-modal{background:var(--color-bg-primary);border-radius:var(--radius-xl);width:90%;max-width:400px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000004d}.invite-info-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.invite-info-modal__header h3{margin:0;font-size:var(--font-size-lg)}.invite-info-modal__content{padding:var(--space-md) var(--space-lg);flex:1;overflow-y:auto}.invite-info-modal__members{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.invite-info-modal__member{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs);border-radius:var(--radius-md);cursor:pointer}.invite-info-modal__member:hover{background:var(--color-bg-secondary)}.invite-info-modal__meta{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-xs);color:var(--color-text-secondary)}.invite-info-modal__actions{display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.invite-info-modal__actions .btn{flex:1}.invite-modal{background:var(--color-bg-primary);border-radius:var(--radius-xl);width:90%;max-width:400px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px var(--color-shadow)}.invite-modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.invite-modal__header h3{margin:0;font-size:var(--font-size-lg);font-weight:600}.invite-modal__close{color:var(--color-text-muted);font-size:24px}.invite-modal__list{flex:1;overflow-y:auto;padding:var(--space-sm) 0}.invite-modal__user{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);cursor:pointer;transition:background .2s}.invite-modal__user:hover{background:var(--color-bg-secondary)}.invite-modal__user input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent)}.invite-modal__name{font-size:var(--font-size-md);flex:1}.invite-modal__empty{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--color-text-secondary)}.invite-modal__hint{font-size:var(--font-size-xs);opacity:.7;margin-top:var(--space-xs)}.invite-modal__error{padding:var(--space-md) var(--space-lg);background:#ef44441a;color:var(--color-danger);font-size:var(--font-size-sm)}.invite-modal__actions{display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.invite-modal__cancel,.invite-modal__send{flex:1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all .2s ease}.invite-modal__cancel{border:1px solid var(--color-border);color:var(--color-text-primary)}.invite-modal__send{background:var(--color-accent);color:var(--color-bg-primary)}.invite-list-header{padding:var(--space-xs) var(--space-lg);font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.avatar-upload-modal{max-width:340px;width:calc(100% - 32px)}.avatar-upload-current{display:flex;justify-content:center;margin-bottom:var(--space-lg)}.avatar-upload-options,.avatar-upload-actions{display:flex;flex-direction:column;gap:var(--space-md)}.avatar-upload-option{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease;width:100%;text-align:left;color:var(--color-text-primary);font-size:var(--font-size-md);font-weight:500}.avatar-upload-option:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent)}.avatar-upload-option:active{transform:scale(.98)}.avatar-upload-option-icon{width:40px;height:40px;border-radius:var(--radius-full);background:var(--color-accent-light);color:var(--color-accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-upload-option-danger{color:var(--color-danger)}.avatar-upload-option-danger .avatar-upload-option-icon{background:var(--color-danger-light);color:var(--color-danger)}.avatar-upload-option-danger:hover{border-color:var(--color-danger)}.avatar-crop-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-md) 0}.avatar-crop-area{position:relative;width:220px;height:220px;overflow:hidden;border-radius:var(--radius-lg);background:var(--color-bg-secondary);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.avatar-crop-area:active{cursor:grabbing}.avatar-crop-mask{position:absolute;inset:0;pointer-events:none;z-index:2;box-shadow:0 0 0 9999px #0006;border-radius:var(--radius-full);margin:10px}.avatar-crop-image{position:absolute;width:auto;height:auto;max-width:none;top:50%;left:50%;transform-origin:center center;pointer-events:none;-webkit-user-select:none;user-select:none}.avatar-zoom-controls{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:0 var(--space-sm)}.avatar-zoom-icon{flex-shrink:0;color:var(--color-text-muted)}.avatar-zoom-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);outline:none}.avatar-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;background:var(--color-accent);border-radius:var(--radius-full);cursor:pointer;border:2px solid var(--color-bg-primary);box-shadow:0 1px 3px #00000026}.avatar-zoom-slider::-moz-range-thumb{width:18px;height:18px;background:var(--color-accent);border-radius:var(--radius-full);cursor:pointer;border:2px solid var(--color-bg-primary);box-shadow:0 1px 3px #00000026}.avatar-upload-preview{display:flex;flex-direction:column;align-items:center}.avatar-preview-image{width:200px;height:200px;border-radius:var(--radius-full);overflow:hidden;border:3px solid var(--color-border)}.avatar-preview-image img{width:100%;height:100%;object-fit:cover}.avatar-upload-progress{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) 0}.avatar-progress-ring{position:relative;width:100px;height:100px}.avatar-progress-ring svg{transform:rotate(-90deg);width:100%;height:100%}.avatar-progress-bg{fill:none;stroke:var(--color-bg-tertiary);stroke-width:6}.avatar-progress-fill{fill:none;stroke:var(--color-accent);stroke-width:6;stroke-linecap:round;stroke-dasharray:283;transition:stroke-dashoffset .3s ease}.avatar-progress-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:600;color:var(--color-accent)}.tooltip-container{display:inline-flex;align-items:center;vertical-align:middle}.tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted);transition:all .2s ease}.tooltip-trigger:hover{color:var(--color-accent)}.tooltip-trigger:active{transform:scale(.92)}.tooltip-content{max-width:min(70vw,300px);background:var(--color-bg-tertiary);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000040;padding:var(--space-sm) var(--space-md);color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:400;line-height:1.4;text-transform:none;pointer-events:none;animation:tooltipFadeIn .2s cubic-bezier(.16,1,.3,1);z-index:2000000}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid;transform:translate(-50%)}.tooltip-content[data-placement=below] .tooltip-arrow{bottom:100%;border-width:0 5px 5px 5px;border-color:transparent transparent var(--color-bg-tertiary) transparent;margin-bottom:-1px;z-index:2}.tooltip-content[data-placement=below] .tooltip-arrow.shadow{bottom:100%;border-width:0 6px 6px 6px;border-color:transparent transparent var(--color-border) transparent;margin-bottom:0;z-index:1}.tooltip-content[data-placement=above] .tooltip-arrow{top:100%;border-width:5px 5px 0 5px;border-color:var(--color-bg-tertiary) transparent transparent transparent;margin-top:-1px;z-index:2}.tooltip-content[data-placement=above] .tooltip-arrow.shadow{top:100%;border-width:6px 6px 0 6px;border-color:var(--color-border) transparent transparent transparent;margin-top:0;z-index:1}@keyframes tooltipFadeIn{0%{opacity:0;transform:scale(.95) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.info-hint-trigger{display:flex;align-items:center;justify-content:center;width:14px;height:14px;color:var(--color-text-muted);transition:all .2s ease}.info-hint-trigger svg{display:block;width:100%;height:100%;opacity:.7}.info-hint-trigger:hover svg{opacity:1}.modern-form-section{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-xs)}.modern-form-row{display:flex;align-items:flex-start}.modern-form-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-xs)}.modern-form-label{display:block;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.group-carousel{position:relative;margin-bottom:var(--space-xs);z-index:10;--group-glow-duration: 1.5s;overflow:visible;margin-inline:calc(var(--space-md) * -1)}.group-carousel__track{display:flex;gap:8px;overflow-x:auto;overflow-y:visible;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-padding-inline:calc(50% - min(35vw,calc(var(--max-width) * .35)));overscroll-behavior-x:contain;padding-top:calc(var(--space-xl) + 8px);padding-bottom:calc(var(--space-xl) + 8px);padding-left:calc(50% - min(35vw,calc(var(--max-width) * .35)));padding-right:calc(50% - min(35vw,calc(var(--max-width) * .35)));margin-block:calc(var(--space-xs) - var(--space-xl) - 8px)}.group-carousel__track::-webkit-scrollbar{display:none}.group-carousel__card{flex:0 0 min(70vw,calc(var(--max-width) * .7));max-width:min(70vw,calc(var(--max-width) * .7));scroll-snap-align:center;scroll-snap-stop:always;border-radius:var(--radius-lg);padding:var(--space-md);background:var(--color-bg-primary);border:2px solid var(--color-border);display:grid;grid-template-rows:var(--group-carousel-header-height) var(--group-carousel-status-height) var(--group-carousel-action-height);min-height:165px;height:165px;cursor:pointer;position:relative;overflow:visible;--group-carousel-header-height: 43px;--group-carousel-status-height: 58px;--group-carousel-action-height: 32px;--group-carousel-right-col-width: 58px;--group-carousel-col-gap: var(--space-sm);transition:border-color .2s ease,box-shadow .2s ease}.group-carousel__card--active{border-color:var(--group-color, var(--color-border))}.group-carousel__card--ready{--glow-shadow-min: 0 4px 16px color-mix(in srgb, var(--group-color, transparent) 26%, transparent);--glow-shadow-max: 0 6px 24px color-mix(in srgb, var(--group-color, transparent) 42%, transparent);animation:group-glow-sync-shadow var(--group-glow-duration, 1.5s) ease-in-out infinite;animation-delay:var(--group-glow-delay, 0ms)}.group-carousel__card--scheduled{box-shadow:0 5px 18px color-mix(in srgb,var(--group-color, var(--color-accent)) 30%,transparent);animation:none}.group-carousel__header{grid-row:1;grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) var(--group-carousel-right-col-width);column-gap:var(--group-carousel-col-gap);align-items:center;width:100%;height:100%}.group-carousel__header-left{min-height:0;display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0;justify-self:start}.group-carousel__title-row{display:flex;align-items:center;gap:var(--space-sm);width:100%;min-width:0}.group-carousel__name-wrap{display:flex;align-items:center;gap:2px;min-width:0;flex:1}.group-carousel__mode-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-muted);flex-shrink:0;padding:var(--space-xs);overflow:visible}.group-carousel__mode-icon svg{display:block;overflow:visible}.group-carousel__mode-icon--ready{color:var(--group-color, var(--color-accent));--glow-filter-min: drop-shadow(0 0 2px color-mix(in srgb, var(--group-color, var(--color-accent)) 34%, transparent));--glow-filter-max: drop-shadow(0 0 6px color-mix(in srgb, var(--group-color, var(--color-accent)) 64%, transparent))}.group-carousel__mode-icon--scheduled{color:var(--group-color, var(--color-accent))}.group-carousel__mode-icon--scheduled svg{filter:drop-shadow(0 0 4px color-mix(in srgb,var(--group-color, var(--color-accent)) 54%,transparent));animation:none}.group-carousel__mode-icon--ready svg{animation:group-glow-sync-filter var(--group-glow-duration, 1.5s) ease-in-out infinite;animation-delay:var(--group-glow-delay, 0ms)}.group-carousel__header-right{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex-shrink:0;width:var(--group-carousel-right-col-width);min-width:var(--group-carousel-right-col-width);justify-self:center;align-self:center}.group-carousel__meta-row{display:flex;align-items:center;gap:var(--space-xs);min-height:18px}.group-carousel__members{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-carousel__meta-row .group-mode-badge{font-size:9px;padding:2px 6px}.group-carousel__emoji{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;font-size:2.5rem;line-height:1}.group-carousel__emoji-image{width:42px;height:42px;border-radius:12px;display:block;object-fit:contain}.group-carousel__emoji-image--legacy{border-radius:0}.group-carousel__members-count{display:inline-flex;align-items:center;justify-content:center;gap:4px;font-size:14px;color:var(--color-text-muted);font-weight:600;line-height:1;min-height:16px;width:auto;font-variant-numeric:tabular-nums}.group-carousel__members-count span{display:inline-block;text-align:center}.group-carousel__members-meta{display:grid;grid-template-rows:minmax(16px,auto) minmax(16px,auto);row-gap:4px;justify-items:center;align-content:center;min-height:36px;width:var(--group-carousel-right-col-width);min-width:var(--group-carousel-right-col-width);align-self:end;justify-self:center;flex-shrink:0}.group-carousel__members-meta--single .group-carousel__members-count{grid-row:1 / span 2;align-self:center}.group-carousel__members-count svg{width:16px;height:16px;stroke-width:2.5}.group-carousel__range-row{display:inline-flex;align-items:center;justify-content:center;gap:2px;min-height:16px;width:auto;font-size:11px;color:var(--color-text-muted);white-space:nowrap}.group-carousel__range-metric-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--color-text-muted);flex-shrink:0}.group-carousel__range-metric-icon svg{display:block}.group-carousel__range-metric-icon--warning{color:#f59e0b}.group-carousel__range-value{display:inline-block;text-align:center;font-variant-numeric:tabular-nums}.group-carousel__range-metric-tooltip{flex-shrink:0}.group-carousel__range-metric-tooltip .tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--color-text-muted);line-height:1;cursor:pointer}.group-carousel__range-metric-tooltip--warning .tooltip-trigger{color:#f59e0b}.group-carousel__range-metric-tooltip--warning .tooltip-trigger:hover{color:#d97706}.group-carousel__name{font-size:var(--font-size-xl);font-weight:600;text-align:left;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:0 1 auto}.group-carousel__settings-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;padding:var(--space-xs);color:var(--color-text-muted);line-height:1}.group-carousel__settings-btn:hover{color:var(--color-text-muted)}.group-carousel__settings-btn:disabled{opacity:.5;cursor:default}.group-carousel__status{grid-row:2;grid-column:1 / -1;display:grid;grid-template-columns:minmax(0,1fr) var(--group-carousel-right-col-width);column-gap:var(--group-carousel-col-gap);align-items:end;font-size:var(--font-size-sm);color:var(--color-text-muted);min-width:0;width:100%;height:100%;overflow:hidden}.group-carousel__status-content{display:flex;align-items:flex-end;justify-self:start;width:100%;min-width:0;overflow:hidden}.group-carousel__status-lines{display:flex;flex-direction:column;gap:1px;width:100%;min-width:0;flex:1;min-height:36px;overflow:hidden}.group-carousel__status-lines--empty{visibility:hidden}.group-carousel__status-lines--single{min-height:36px;justify-content:center}.group-carousel__status-activity{display:flex;align-items:center;gap:var(--space-xs);width:100%;min-width:0;min-height:16px;overflow:hidden}.group-carousel__status-activity-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.group-carousel__status-time{min-height:16px;display:block;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.8}.group-carousel__actions{grid-row:3;grid-column:1 / -1;display:flex;align-items:stretch;gap:var(--space-sm);width:100%;height:100%;margin-top:0;padding-top:var(--space-sm)}.group-carousel__card:not(.group-carousel__card--active) .group-carousel__actions{pointer-events:none}.group-carousel__actions .btn{flex:1;min-height:0;height:100%}.group-carousel__btn-primary{background-color:var(--group-color, var(--color-accent));color:#fff}.group-carousel__btn-stop{background-color:color-mix(in srgb,var(--group-color, var(--color-accent)) 70%,var(--color-bg-tertiary));color:var(--color-text-primary)}@media(hover:hover){.group-carousel__btn-primary:hover{background-color:color-mix(in srgb,var(--group-color, var(--color-accent)) 85%,black);color:#fff;box-shadow:0 4px 14px color-mix(in srgb,var(--group-color, var(--color-accent)) 35%,transparent)}.group-carousel__btn-stop:hover{background-color:color-mix(in srgb,var(--group-color, var(--color-accent)) 24%,var(--color-bg-tertiary));border-color:color-mix(in srgb,var(--group-color, var(--color-accent)) 58%,transparent)}}.group-carousel__card--add{display:flex;flex-direction:column;border-style:dashed;border-color:var(--color-text-muted);justify-content:center;align-items:center;transition:opacity .2s ease,transform .3s ease,box-shadow .3s ease}.group-carousel__card--add.group-carousel__card--active{box-shadow:0 8px 22px color-mix(in srgb,var(--color-text-muted) 28%,transparent)}.group-carousel__card--add:hover,.group-carousel__card--add:active{opacity:1;box-shadow:0 8px 22px color-mix(in srgb,var(--color-text-muted) 28%,transparent)}.group-carousel__add-icon{font-size:2.5rem;color:var(--color-text-muted);line-height:1}.group-carousel__add-text{font-size:var(--font-size-sm);color:var(--color-text-muted)}.pagination-wrapper{position:relative;z-index:20}.pagination-dots{display:flex;justify-content:center;gap:var(--space-md);padding:var(--space-xs) 0 var(--space-sm);margin-bottom:var(--space-sm);transition:transform .3s cubic-bezier(.25,1,.5,1);width:max-content;margin-left:auto;margin-right:auto}.pagination-dot{display:flex;text-align:center;justify-content:center;align-items:center;background:none;border:none;cursor:pointer;padding:0;transition:transform .2s ease,opacity .2s ease;opacity:.5}.pagination-dot--active{transform:scale(1.18);opacity:1}.pagination-dot__emoji{font-size:.7rem;text-align:center;line-height:1;display:flex;justify-content:center;align-items:center}.pagination-dot__icon-image{width:12px;height:12px;border-radius:3px;display:block;transform:none;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.pagination-dot__icon-mask{width:12px;height:12px;display:block;transform:none;-webkit-mask-image:url(/logo-inverted-cropped.svg);mask-image:url(/logo-inverted-cropped.svg);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain}.pagination-dot__icon-mask--bg{background-color:var(--color-bg-primary)}.pagination-dot__indicator{width:20px;height:20px;border-radius:var(--radius-full);border:2px solid var(--dot-color, var(--color-text-muted));background:transparent;transition:all .25s ease;display:flex;justify-content:center;align-items:center}.pagination-dot--inactive .pagination-dot__indicator{background:transparent}.pagination-dot--scheduled .pagination-dot__indicator{background:var(--dot-color, var(--color-text-muted));box-shadow:0 0 8px 2px color-mix(in srgb,var(--dot-color, var(--color-text-muted)) 58%,transparent)}.pagination-dot--ready .pagination-dot__indicator{background:var(--dot-color, var(--color-accent));--glow-shadow-min: 0 0 6px 2px var(--dot-color, var(--color-accent));--glow-shadow-max: 0 0 12px 4px var(--dot-color, var(--color-accent));animation:group-glow-sync-shadow var(--group-glow-duration, 1.5s) ease-in-out infinite;animation-delay:var(--group-glow-delay, 0ms)}@keyframes group-glow-sync-shadow{0%,to{box-shadow:var(--glow-shadow-min, none)}50%{box-shadow:var(--glow-shadow-max, none)}}@keyframes group-glow-sync-filter{0%,to{filter:var(--glow-filter-min, none)}50%{filter:var(--glow-filter-max, none)}}.active-groups-section{margin-top:var(--space-md)}.active-groups-section .section-title{margin-bottom:var(--space-sm)}.group-create{display:flex;flex-direction:column;gap:var(--space-md);height:clamp(360px,58vh,500px);min-height:0}.group-create-modal .modal-body{overflow:hidden}.group-create__step-content{flex:1;min-height:0;overflow:hidden;display:flex}.group-create__step-scroll{flex:1;min-height:0;height:100%;display:flex;flex-direction:column;gap:var(--space-md);overflow:hidden}.group-create__step-scroll--step2{justify-content:flex-start}.group-create__step-scroll--fill{min-height:0}.group-create__field-block{display:flex;flex-direction:column;gap:var(--space-sm);min-height:0}.group-create__invite-selector{min-height:0}.group-create__invite-selector--fill{display:flex;flex-direction:column;gap:var(--space-xs);flex:1;min-height:0}.group-create__field-block>.form-label,.group-create__step-scroll>.form-label{margin-top:var(--space-xs);margin-bottom:var(--space-xs)}.group-create__step-scroll>.group-create__field-block:first-child>.form-label{margin-top:0}.group-create__field-block--fill{flex:1}.group-create__step-indicator{display:flex;gap:var(--space-sm);justify-content:center;margin-top:var(--space-xs)}.group-create .modal-actions{margin-top:var(--space-xs)}.group-create__step-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--color-border);transition:background .2s ease}.group-create__step-dot--active{background:var(--color-accent)}.group-create__step-dot--done{background:var(--color-accent);opacity:.5}.group-create__identity-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,4fr);gap:var(--space-lg);align-items:stretch}.group-create__identity-grid>div{display:flex;flex-direction:column;gap:var(--space-sm);min-height:100%}.group-create__identity-grid>div>.form-label{min-height:1.2em}.group-create__identity-grid>div>:last-child{margin-top:auto}.group-create__emoji-controls{position:relative;display:flex;align-items:center;width:fit-content}.group-create__emoji-overlay{top:auto;right:-6px;bottom:-6px}.group-create__emoji-overlay:disabled{opacity:.55;cursor:not-allowed;transform:none}.group-create__emoji-overlay:disabled:hover{background:var(--color-bg-tertiary);transform:none}.group-create__emoji-preview{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:var(--radius-md);background:var(--color-bg-secondary);border:2px solid var(--color-border)}.emoji-picker{width:100%}.emoji-picker .EmojiPickerReact{border:none!important;width:100%!important}.hue-ring-picker{display:flex;align-items:center;gap:var(--space-lg);justify-content:center}.hue-ring-picker__preview{width:48px;height:48px;border-radius:var(--radius-full);border:3px solid var(--color-border);flex-shrink:0;box-shadow:0 2px 8px #00000026}.hue-ring-picker__ring-svg{flex-shrink:0;cursor:pointer}.hue-ring-picker__ring-handle{stroke:#fff;stroke-width:2px;filter:drop-shadow(0 0 .5px rgba(0,0,0,.35)) drop-shadow(0 2px 6px var(--color-shadow));pointer-events:none}.group-create__type-selector{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-sm)}.group-create__type-option{width:100%;min-width:0;padding:var(--space-md) var(--space-sm);border-radius:var(--radius-lg);border:2px solid var(--color-border);background:var(--color-bg-secondary);cursor:pointer;text-align:center;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);transition:border-color .2s ease,background .2s ease}.group-create__type-option--selected{border-color:var(--color-accent);background:var(--color-accent-light)}.group-create__type-icon-wrap{width:42px;height:42px;border-radius:var(--radius-full);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.group-create__type-option--selected .group-create__type-icon-wrap{background:var(--color-accent);color:#fff}.group-create__type-title{font-weight:600;font-size:var(--font-size-sm)}.group-create__type-subtitle{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.3}.group-create__preset-list{display:flex;flex-direction:column;gap:var(--space-xxs);overflow-y:auto;padding-right:2px}.group-create__preset-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.group-create__preset-main{flex:1;min-width:0;display:flex;align-items:baseline;gap:var(--space-xs)}.group-create__preset-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-create__preset-coords{flex-shrink:0;white-space:nowrap;font-size:.6875rem;line-height:1.2;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-variant-numeric:tabular-nums}.group-create__preset-editor{display:flex;flex-direction:column;min-height:0}.group-create__preset-editor--fill{flex:1}.group-create__preset-add{margin-top:var(--space-sm);width:fit-content}.group-create__preset-add--bottom{margin-top:auto}.group-create__preset-add--full{width:100%}.group-create__type-icon{font-size:1.5rem;margin-bottom:var(--space-xs)}.group-create__type-label{font-weight:600;font-size:var(--font-size-sm)}.group-create__type-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--space-xxs)}.group-create__members-list{display:flex;flex-direction:column;gap:var(--space-xs);max-height:300px;overflow-y:auto}.group-create__member-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.group-create__member-item:hover{background:var(--color-bg-secondary)}.group-create__member-item--selected{background:var(--color-accent-light)}.group-create__member-name{flex:1;font-weight:500}.group-create__member-check{width:20px;height:20px;border-radius:var(--radius-full);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;transition:all .15s ease}.group-create__member-check--selected{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.group-settings{padding:var(--space-md)}.group-settings-page{background-color:var(--color-bg-primary)}.group-settings-page .page-scroll{position:relative;overflow-x:hidden;isolation:isolate}.group-settings-page .page-scroll>.container{position:relative;padding-left:calc(var(--space-md) + env(safe-area-inset-left,0px));padding-right:calc(var(--space-md) + env(safe-area-inset-right,0px));z-index:2}.group-settings-page .page-scroll:before{content:"";position:absolute;top:calc(-1*env(safe-area-inset-top,0px));left:0;right:0;height:clamp(96px,calc(18vh + env(safe-area-inset-top,0px)),200px);background:radial-gradient(110% 75% at 25% 0%,var(--group-accent-color, var(--color-accent)) 0%,transparent 66%);opacity:.18;pointer-events:none;z-index:1}.group-settings-page .page-scroll>.container>*{position:relative;z-index:1}.group-settings__header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg)}.group-settings__emoji{font-size:2rem}.group-settings__emoji-image{display:block}.group-settings__emoji-image--legacy{width:30px;height:30px}.group-settings__title{font-size:var(--font-size-xl);font-weight:600}.group-settings__section{margin-bottom:var(--space-lg)}.group-settings__section-title{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--space-sm);color:var(--color-text-secondary)}.group-settings-page .page-tabs{margin-bottom:var(--space-md)}.stats-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;color:var(--color-text-muted);gap:var(--space-md)}.stats-placeholder svg{width:48px;height:48px;opacity:.5}.category-picker{display:flex;flex-direction:column;gap:var(--space-md)}.category-picker__list{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.category-picker__pill{display:inline-flex;align-items:center;gap:var(--space-xxs);border-radius:var(--radius-md);border:none;background:var(--color-bg-secondary);color:inherit}.category-picker__pill-label{border:none;background:transparent;color:var(--color-text-primary);font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-sm) var(--space-sm) var(--space-md);cursor:pointer;border-radius:calc(var(--radius-md) - 2px);transition:background-color .15s,color .15s}.category-picker__pill-label--selected,.category-picker__pill-label[aria-pressed=true]{color:#fff}.category-picker__pill-label--static{cursor:default}.category-picker__pill-label--no-remove{padding-right:var(--space-md)}.category-picker__pill-remove{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-muted);padding:0 var(--space-sm) 0 var(--space-xxs);line-height:1;cursor:pointer}.category-picker__pill:hover{background:var(--color-bg-tertiary)}.category-picker__pill--selected,.category-picker__pill--selected:hover,.category-picker__pill--selected:focus-within{background:var(--color-accent)}.category-picker__pill--selected .category-picker__pill-label,.category-picker__pill--selected .category-picker__pill-remove{color:#fff}.category-picker__pill-remove svg{width:12px;height:12px}.category-picker__add-pill{border:1px dashed var(--color-border);border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);width:34px;height:34px;font-size:var(--font-size-lg);line-height:1;cursor:pointer}.category-picker__add-pill:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-bg-secondary)}.category-picker__defaults-editor{display:flex;align-items:center;gap:var(--space-xs)}.category-picker__defaults-editor .category-picker__custom-input{flex:1}.category-picker__custom{display:flex;flex-direction:column;gap:var(--space-xs)}.category-picker__custom-input{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm)}.category-picker__custom-input:focus{outline:none;border-color:var(--color-accent)}.category-picker__item{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:none;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:background-color .15s,color .15s}.category-picker__item:hover{background:var(--color-bg-tertiary)}.category-picker__item--selected{background:var(--color-accent);color:#fff}.friend-multi-select{display:flex;flex-direction:column;gap:var(--space-xs);overflow:hidden;min-height:0}.friend-multi-select--fill{flex:1;min-height:0;max-height:none!important}.friend-multi-select__search-wrap{flex-shrink:0}.friend-multi-select__search{width:100%;padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm)}.friend-multi-select__search:focus{outline:none;border-color:var(--color-accent)}.friend-multi-select__list{display:flex;flex-direction:column;gap:var(--space-xs);overflow-y:auto;min-height:0;flex:1}.friend-multi-select__empty{padding:var(--space-xs) var(--space-sm)}.friend-multi-select__section-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;padding:var(--space-xs) var(--space-sm);margin-top:var(--space-xs)}.friend-multi-select__section-label:first-child{margin-top:0}.friend-multi-select__item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease;border:none;background:none;width:100%;text-align:left;color:var(--color-text-primary);font-size:var(--font-size-md)}.friend-multi-select__item:hover{background:var(--color-bg-secondary)}.friend-multi-select__item--selected{background:var(--color-accent-light)}.friend-multi-select__checkbox{width:20px;height:20px;border-radius:var(--radius-sm);border:2px solid var(--color-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.friend-multi-select__checkbox--checked{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.friend-multi-select__name{flex:1;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.page-tabs{display:flex;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-bg-primary);z-index:10;margin-bottom:4px}.page-tab{flex:1;padding:var(--space-sm) var(--space-md);text-align:center;font-weight:500;color:var(--color-text-muted);border:none;background:none;cursor:pointer;position:relative;transition:color .2s ease;font-size:var(--font-size-md);display:flex;align-items:center;justify-content:center;gap:var(--space-xs);margin-bottom:0}.page-tab--active{color:var(--color-accent)}.page-tab--active:after{content:"";position:absolute;bottom:-1px;left:var(--space-lg);right:var(--space-lg);height:2px;background:var(--color-accent);border-radius:var(--radius-full)}.page-tab svg{width:18px;height:18px}.page-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:var(--font-size-xs);font-weight:600;margin-left:var(--space-xs)}.EmojiPickerReact .epr-cat-btn:focus:before{display:none!important}.EmojiPickerReact .epr-cat-btn.epr-active,.EmojiPickerReact .epr-cat-btn:hover,.EmojiPickerReact .epr-cat-btn:focus{background-color:transparent!important;filter:hue-rotate(-58deg) saturate(1.85) brightness(.95)}.EmojiPickerReact .epr-search-container input{background:transparent!important;border:none!important;border-bottom:1px solid var(--color-border)!important;border-radius:0!important;color:var(--color-text-primary)!important;font-size:var(--font-size-md)!important;height:auto!important;min-height:36px;padding:var(--space-sm) 28px var(--space-sm) 30px!important;transition:border-color .2s!important}.EmojiPickerReact .epr-search-container input:focus{background:transparent!important;border:none!important;border-bottom:1px solid var(--color-accent)!important;box-shadow:none!important}.EmojiPickerReact .epr-search-container input::placeholder{color:var(--color-text-placeholder)!important}.EmojiPickerReact .epr-icn-search{left:2px!important;width:18px!important;height:18px!important;pointer-events:none}.EmojiPickerReact .epr-btn-clear-search{right:0!important}.context-menu-emoji-picker-popover .EmojiPickerReact.epr-reactions{border-radius:var(--radius-lg);background:var(--color-bg-primary)}.context-menu-emoji-picker-popover .EmojiPickerReact.epr-reactions .epr-btn:hover,.context-menu-emoji-picker-popover .EmojiPickerReact.epr-reactions .epr-btn:focus{background:var(--color-bg-secondary)}.landing-page{min-height:100vh;display:flex;flex-direction:column;padding:var(--space-lg);padding-top:calc(var(--space-lg) + env(safe-area-inset-top));padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom));padding-left:calc(var(--space-lg) + env(safe-area-inset-left));padding-right:calc(var(--space-lg) + env(safe-area-inset-right));max-width:var(--max-width);margin:0 auto}.landing-screen{height:100vh;justify-content:center;overflow:hidden}.landing-hero{text-align:center;padding:var(--space-xl) 0;margin-top:auto}.landing-logo{width:80px;height:80px;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-lg);color:#fff}.landing-title{font-size:var(--font-size-3xl);color:var(--color-accent);margin-bottom:var(--space-sm)}.landing-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.6}.landing-features{display:flex;flex-direction:column;gap:var(--space-md);margin:var(--space-xl) 0}.landing-feature{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg)}.landing-feature-icon{font-size:var(--font-size-xl)}.landing-cta{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.landing-install{background-color:var(--color-bg-secondary);padding:var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.landing-install h2{font-size:var(--font-size-lg);margin-bottom:var(--space-sm)}.install-steps{display:flex;flex-direction:column;gap:var(--space-sm)}.install-step{display:flex;gap:var(--space-md);align-items:flex-start}.install-step-num{width:24px;height:24px;background-color:var(--color-accent);color:#fff;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:600;flex-shrink:0}.landing-footer{margin-top:auto;text-align:center;padding:var(--space-lg) 0}.home-title{font-size:var(--font-size-2xl);margin-bottom:var(--space-lg)}.section-title{font-size:var(--font-size-lg);margin-bottom:var(--space-md)}.greeter{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);min-height:32px}.greeter-text{margin:0;color:var(--color-text-secondary);font-size:var(--font-size-md)}.greeter-status{display:flex;align-items:center;gap:var(--space-xs)}.greeter-count{font-weight:600;font-size:var(--font-size-sm);margin-right:4px}.greeter-count--ready{color:var(--color-accent)}.greeter-count--soon{color:var(--color-text-muted)}.greeter-divider{color:var(--color-text-muted);opacity:.4;margin:0 var(--space-xs)}.greeter-warning{cursor:pointer;font-size:14px;margin-left:var(--space-xs)}.active-groups-list>.unified-list-item:not(:last-child){margin-bottom:var(--space-sm)}.active-groups-list>.unified-list-item:after{bottom:calc(var(--space-sm) * -.5)}.chat-container{display:flex;flex-direction:column;height:100%}.group-messages{flex:1;overflow-y:auto;min-height:0;padding:var(--space-md);padding-top:calc(var(--group-header-height, 140px) + var(--space-sm));display:flex;flex-direction:column;-webkit-overflow-scrolling:touch;position:relative;padding-bottom:calc(var(--chat-input-height, 80px) + var(--space-md))}.group-messages-wrapper{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;width:100%;max-width:var(--max-width);margin:0 auto;margin-bottom:calc(var(--chat-input-height, 0px) * -1)}.scroll-to-bottom-wrapper{position:absolute;bottom:0;left:0;right:0;pointer-events:none;z-index:90;display:flex;justify-content:center}.scroll-to-bottom-inner{width:100%;max-width:var(--max-width);position:relative;height:0}.scroll-to-bottom-btn{position:absolute;bottom:var(--space-md);right:var(--space-md);width:40px;height:40px;border-radius:50%;background:var(--color-bg-primary);border:1px solid var(--color-border);box-shadow:0 2px 8px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:transform .2s,opacity .2s,box-shadow .2s;color:var(--color-text-secondary)}.scroll-to-bottom-btn svg{width:20px;height:20px}.scroll-to-bottom-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.scroll-to-bottom-btn:active{transform:scale(.95)}.chat-message{padding:6px 12px;border-radius:var(--radius-lg);margin-bottom:var(--space-xs);line-height:1.35;white-space:pre-wrap;word-break:break-word;font-size:var(--font-size-sm);position:relative}.chat-message-sender{color:hsl(var(--user-hue),70%,45%);font-weight:600;margin-bottom:2px}@media(prefers-color-scheme:dark){.chat-message-sender{color:hsl(var(--user-hue),70%,65%)}}.chat-message.own{align-self:flex-end;background-color:rgba(var(--color-accent-rgb),.8);-webkit-backdrop-filter:blur(10px) brightness(1.2);backdrop-filter:blur(10px) brightness(1.2);color:#fff;border-bottom-right-radius:var(--radius-sm);margin-left:var(--space-xl)}.chat-message.other{align-self:flex-start;background-color:var(--color-bg-tertiary);border-bottom-left-radius:var(--radius-sm);margin-right:var(--space-xl)}.chat-message.group-start,.chat-message.group-middle{margin-bottom:var(--space-xs)}.chat-message.group-end{margin-bottom:var(--space-md)}.chat-message.own.group-middle,.chat-message.own.group-end:not(.group-start){border-top-right-radius:var(--radius-md)}.chat-message.other.group-middle,.chat-message.other.group-end:not(.group-start){border-top-left-radius:var(--radius-md)}.chat-message.system{align-self:center;background-color:transparent;color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic;text-align:center;margin-top:var(--space-xs);margin-bottom:var(--space-xs)}.chat-timestamp{font-size:10px;margin-left:8px;float:right;margin-top:6px;opacity:.7;-webkit-user-select:none;user-select:none;line-height:1}.chat-message.own .chat-timestamp{color:#fffc}.chat-message.other .chat-timestamp{color:var(--color-text-muted)}.message-reply-header{margin-bottom:4px;padding:4px 8px;background:#0000000d;border-left:3px solid var(--color-accent);border-radius:4px;font-size:11px;cursor:pointer;display:flex;flex-direction:column;gap:2px}.chat-message.own .message-reply-header{background:#ffffff26;border-left-color:#fffc}.reply-sender{font-weight:600;color:hsl(var(--user-hue),70%,45%)}.chat-message.own .reply-sender{color:#fff}@media(prefers-color-scheme:dark){.reply-sender{color:hsl(var(--user-hue),70%,75%)}.message-reply-header{background:#ffffff1a}}.reply-text{opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-input-wrapper{position:relative;z-index:100;background:transparent;display:flex;flex-direction:column;flex-shrink:0;width:100%}.chat-input-bar{display:flex;justify-content:center;padding:var(--space-sm);padding-bottom:calc(var(--space-sm) + env(safe-area-inset-bottom));background:rgba(var(--color-bg-primary-rgb),.85);backdrop-filter:var(--backdrop-primary);-webkit-backdrop-filter:var(--backdrop-primary);border-top:1px solid rgba(var(--color-border-rgb),.5)}.group-page.keyboard-open .chat-input-bar{padding-bottom:var(--space-sm)}.chat-input-inner{display:flex;align-items:center;gap:var(--space-sm);width:100%;max-width:var(--max-width)}.chat-input-editable{flex:1;min-height:40px;max-height:120px;padding:10px 12px;background:var(--color-bg-tertiary);border-radius:20px;border:1px solid transparent;font-size:var(--font-size-md);outline:none;overflow-y:auto;white-space:pre-wrap;word-break:break-word;color:var(--color-text-primary);transition:border-color .2s}.chat-input-editable:focus{border-color:var(--color-accent)}.chat-input-editable:empty:before{content:attr(data-placeholder);color:var(--color-text-muted);cursor:text}.btn-quick-actions,.btn-send{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;cursor:pointer;flex-shrink:0;transition:all .2s;background:transparent;color:var(--color-text-secondary)}.btn-quick-actions:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-quick-actions.is-open{background:var(--color-bg-tertiary);transform:rotate(45deg)}.btn-send{background:var(--color-accent);color:#fff}.btn-send:disabled{background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:not-allowed;opacity:.7}.quick-actions-container{background:var(--color-bg-primary);overflow:hidden;max-height:0;transition:max-height .25s cubic-bezier(.4,0,1,1);box-shadow:0 -4px 12px #0000001a;display:flex;justify-content:center;width:100%}.quick-actions-container.is-open{max-height:300px;border-top:1px solid var(--color-border);transition:max-height .3s cubic-bezier(0,0,.2,1)}.quick-actions-content{width:100%;max-width:var(--max-width)}.quick-actions-panel{display:flex;justify-content:center;gap:var(--space-md);padding:var(--space-md);width:100%;max-width:var(--max-width)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);transition:all .2s;flex:1;max-width:80px}.quick-action-btn:hover{color:var(--color-accent);transform:translateY(-2px)}.quick-action-icon{width:48px;height:48px;border-radius:50%;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--color-text-primary)}.quick-action-btn:hover .quick-action-icon{background:var(--color-accent-light);color:var(--color-accent)}.quick-action-label{font-size:var(--font-size-xs);font-weight:500}.mention-autocomplete{position:absolute;bottom:100%;left:0;min-width:200px;max-width:280px;max-height:200px;overflow-y:auto;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 -4px 20px #00000026;z-index:1000;margin-bottom:var(--space-xs)}.mention-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:background .15s}.mention-item:hover,.mention-item.selected{background:var(--color-bg-secondary)}.mention-item-name{font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-tag{display:inline;color:hsl(var(--user-hue, 200),70%,45%);font-weight:600;cursor:default}@media(prefers-color-scheme:dark){.mention-tag{color:hsl(var(--user-hue, 200),70%,65%)}}.mention-highlight{color:hsl(var(--user-hue, 200),70%,45%);font-weight:600;cursor:pointer;transition:opacity .15s}.mention-highlight:hover{opacity:.8}@media(prefers-color-scheme:dark){.mention-highlight{color:hsl(var(--user-hue, 200),70%,65%)}}.chat-message.own .mention-highlight,.chat-message.own .mention-highlight.mention-in-own{color:#fde047;text-decoration:none;font-weight:700;background:#00000026;padding:0 3px;border-radius:3px}.reply-preview{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);width:100%;max-width:var(--max-width);background:rgba(var(--color-bg-secondary-rgb),.7);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-left:3px solid var(--color-accent);border-radius:0;margin:0 auto}.reply-preview-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;cursor:pointer;transition:opacity .15s}.reply-preview-content:hover{opacity:.8}.reply-preview-content:active{opacity:.6}.reply-preview-sender{font-size:var(--font-size-xs);font-weight:600;color:hsl(var(--user-hue, 200),70%,45%)}@media(prefers-color-scheme:dark){.reply-preview-sender{color:hsl(var(--user-hue, 200),70%,65%)}}.reply-preview-text{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reply-preview-dismiss{flex-shrink:0;padding:var(--space-xs);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;transition:all .15s;-webkit-tap-highlight-color:transparent}.reply-preview-dismiss:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.reply-preview-dismiss:active{transform:scale(.95)}.context-menu-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;pointer-events:none}.context-menu-overlay.visible{opacity:1;pointer-events:auto}.context-menu-backdrop{position:absolute;inset:0;background:#0003;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.context-menu-container{position:absolute;display:flex;flex-direction:column;z-index:10001;transform-origin:center center}.context-menu-emoji-picker-popover{position:fixed;z-index:3;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-primary);box-shadow:0 10px 24px #00000047}.context-menu-emoji-picker-popover .EmojiPickerReact{border:none!important}.context-menu-message-clone{box-shadow:0 8px 24px #00000040;pointer-events:none}.context-menu-actions-wrapper{position:absolute;top:100%;margin-top:8px}.context-menu-actions-inner{display:flex;flex-direction:column;width:200px;background:var(--color-bg-primary);border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #0003;animation:slideDown .15s cubic-bezier(.175,.885,.32,1.275)}.context-menu-container.align-left .context-menu-actions-wrapper{left:0;transform:translate(var(--popup-offset, 0px))}.context-menu-container.align-right .context-menu-actions-wrapper{left:auto;right:0;transform:translate(var(--popup-offset, 0px))}.context-menu-action-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;border:none;background:transparent;width:100%;text-align:left;font-size:14px;font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:background .1s}.context-menu-action-btn:hover{background:var(--color-bg-secondary)}.context-menu-action-btn.danger{color:var(--color-danger)}.context-menu-action-btn.danger:hover{background:var(--color-danger);color:var(--color-text-primary)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message-reply-header{display:flex;flex-direction:column;gap:2px;padding:var(--space-xs) var(--space-sm);margin:calc(-1 * var(--space-xs)) calc(-1 * var(--space-sm));margin-bottom:var(--space-xs);background:#0000000d;border-radius:var(--radius-md) var(--radius-md) 0 0;border-left:2px solid var(--color-accent);cursor:pointer;transition:background .15s}.message-reply-header:hover{background:#00000014}@media(prefers-color-scheme:dark){.message-reply-header{background:#ffffff0d}.message-reply-header:hover{background:#ffffff14}}.chat-message.own .message-reply-header{background:#0000001a;border-left-color:#ffffff80}.chat-message.own .message-reply-header:hover{background:#00000026}.message-reply-header .reply-sender{font-size:var(--font-size-xs);font-weight:600;color:hsl(var(--user-hue, 200),70%,45%)}@media(prefers-color-scheme:dark){.message-reply-header .reply-sender{color:hsl(var(--user-hue, 200),70%,65%)}}.chat-message.own .message-reply-header .reply-sender{color:#ffffffd9}.message-reply-header .reply-text{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.chat-message.own .message-reply-header .reply-text{color:#ffffffb3}.message-highlight{animation:messageHighlight 1.5s ease-out}@keyframes messageHighlight{0%,30%{box-shadow:0 0 0 3px var(--color-accent)}to{box-shadow:0 0 #0000}}.chat-message.deleted{align-self:center;background:transparent;padding:var(--space-xs) var(--space-md)}.deleted-text{font-size:var(--font-size-sm);font-style:italic;color:var(--color-text-muted);opacity:.7}.message-reactions{position:absolute;bottom:-18px;right:0;z-index:5;display:flex;flex-wrap:nowrap;gap:2px;padding:2px;background:var(--color-bg-primary);border-radius:12px;box-shadow:0 2px 4px #0000001a}.chat-message.other .message-reactions{right:auto;left:0}.chat-message.has-reactions{margin-bottom:24px!important;padding-bottom:6px}.message-reactions:empty{display:none}.reaction-badge{display:inline-flex;align-items:center;gap:2px;padding:2px 5px;background:var(--color-bg-secondary);border:1px solid transparent;border-radius:10px;font-size:11px;cursor:pointer;transition:all .15s;min-height:20px}.reaction-badge:hover{background:var(--color-bg-tertiary);transform:scale(1.1)}.reaction-badge.reacted{background:rgba(var(--color-accent-rgb),.15);border-color:transparent;color:var(--color-accent)}.reaction-emoji{font-size:12px;line-height:1}.reaction-count{font-size:10px;font-weight:600;color:inherit}.chat-message.own .reaction-badge{background:var(--color-bg-secondary);border-color:transparent}.chat-message.own .reaction-badge.reacted{background:rgba(var(--color-accent-rgb),.15);border-color:transparent}.group-page{display:flex;flex-direction:column;height:var(--viewport-height, 100dvh);position:fixed;top:0;left:0;right:0;background-color:var(--color-bg-primary);z-index:200;overflow:hidden;transition:transform .3s cubic-bezier(0,0,.2,1);--group-flare-inset-left: calc(var(--space-md) + env(safe-area-inset-left, 0px));--group-flare-inset-right: calc(var(--space-md) + env(safe-area-inset-right, 0px))}.group-page:before{content:"";position:absolute;top:calc(-1*env(safe-area-inset-top,0px));left:calc(-1 * var(--group-flare-inset-left));right:calc(-1 * var(--group-flare-inset-right));height:clamp(120px,calc(var(--group-header-height, 140px) + 56px + env(safe-area-inset-top,0px)),340px);background:radial-gradient(120% 85% at 25% 0%,var(--group-accent-color, var(--color-accent)) 0%,transparent 72%);opacity:.5;pointer-events:none;z-index:0;transition:height .3s cubic-bezier(0,0,.2,1),opacity .3s ease}.group-page.metadata-collapsed:before{height:clamp(88px,calc(var(--group-header-height, 88px) + 80px),250px);opacity:.5}.group-page:after{content:"";position:absolute;left:calc(-1 * var(--group-flare-inset-left));right:calc(-1 * var(--group-flare-inset-right));bottom:calc(-1*env(safe-area-inset-bottom,0px));height:clamp(56px,calc(10vh + env(safe-area-inset-bottom,0px)),120px);background:radial-gradient(115% 90% at 75% 100%,var(--group-accent-color, var(--color-accent)) 0%,transparent 90%);opacity:.1;pointer-events:none;z-index:0}.group-fixed-header{position:absolute;top:0;left:0;right:0;z-index:50;flex-shrink:0;padding:var(--space-md);padding-top:calc(var(--space-md) + env(safe-area-inset-top));background-color:rgba(var(--color-bg-primary-rgb),.85);backdrop-filter:var(--backdrop-primary);-webkit-backdrop-filter:var(--backdrop-primary);border-bottom:1px solid rgba(var(--color-border-rgb),.5);width:100%;box-sizing:border-box;touch-action:none;display:flex;flex-direction:column;gap:0;align-items:center}.group-fixed-header>*{width:100%;max-width:var(--max-width)}.group-top-bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.group-title{font-size:var(--font-size-lg);font-weight:600;flex:1}.group-title-emoji{font-size:1.1em;line-height:1;flex-shrink:0}.group-title-emoji-image{width:1em;height:1em;display:block;object-fit:contain}.group-title-emoji-image--legacy{width:1.5em;height:1.5em}.group-title-text{min-width:0}.member-info-panel{max-height:0;overflow:hidden;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);border-bottom:1px solid var(--color-border);margin-top:-1px;margin-bottom:0;width:100%;max-width:var(--max-width)}.member-info-panel--open{max-height:50vh;opacity:1;border-bottom:none;margin-bottom:var(--space-sm)}.group-metadata{padding:var(--space-sm) var(--space-sm) 0 var(--space-sm);border-radius:var(--radius-lg);max-height:500px;opacity:1;transform-origin:top;transform:scaleY(1);overflow:hidden;transition:all .3s cubic-bezier(0,0,.2,1);margin-bottom:0}.group-page.metadata-collapsed .group-metadata{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin:0;border:none;pointer-events:none}.metadata-row{display:flex;align-items:center;gap:var(--space-md);font-size:var(--font-size-md);color:var(--color-text-primary)}.metadata-bottom{display:flex;gap:var(--space-sm);margin-top:calc(var(--space-sm) + var(--space-xs));border-top:1px solid var(--color-border);padding-top:calc(var(--space-sm) + var(--space-xs))}.metadata-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);width:20px}.decision-buttons{display:flex;align-items:center;width:100%;gap:var(--space-sm);transition:gap .3s cubic-bezier(.2,0,0,1)}.decision-buttons.has-selection{gap:0}.btn-decision{display:flex;align-items:center;justify-content:center;cursor:pointer;border:1px solid var(--color-border);background:transparent;overflow:hidden;white-space:nowrap;flex:1 1 0%;min-width:0;transition:flex .3s cubic-bezier(.2,0,0,1),width .3s cubic-bezier(.2,0,0,1),padding .3s cubic-bezier(.2,0,0,1),margin .3s cubic-bezier(.2,0,0,1),opacity .3s cubic-bezier(.2,0,0,1),background-color .2s ease,border-color .2s ease,color .2s ease}.btn-decision.hidden{flex:0 0 0%!important;width:0!important;padding:0!important;margin:0!important;opacity:0;border-width:0!important;pointer-events:none}.btn-decision.selected{flex:1 1 0%}.decision-buttons-normal .btn-decision{height:auto;min-height:36px;border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);gap:var(--space-sm)}.decision-buttons-normal .btn-accept:not(.selected){border-color:var(--color-accent);color:var(--color-accent)}.decision-buttons-normal .btn-decline:not(.selected){border-color:var(--color-danger);color:var(--color-danger)}.decision-buttons-normal .btn-accept.selected{background:var(--color-accent);border-color:var(--color-accent-hover);color:#1a1a1a}.decision-buttons-normal .btn-decline.selected{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-decision:not(:disabled):hover{filter:brightness(.95)}.btn-decision:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.5)}.decision-buttons-compact{width:calc(64px + var(--space-sm));flex:0 0 calc(64px + var(--space-sm))}.decision-buttons-compact .btn-decision{width:32px;height:32px;padding:0;border-radius:var(--radius-md);flex:0 0 32px}.decision-buttons-compact .btn-decision.selected{flex:0 0 calc(64px + var(--space-sm));width:calc(64px + var(--space-sm))}.decision-buttons-compact .btn-decision.hidden{flex:0 0 0%!important;width:0!important}.decision-buttons-compact .btn-accept:not(.selected){border-color:var(--color-accent);color:var(--color-accent)}.decision-buttons-compact .btn-decline:not(.selected){border-color:var(--color-danger);color:var(--color-danger)}.decision-buttons-compact .btn-accept.selected{background:var(--color-accent);border-color:var(--color-accent-hover);color:#fff}.decision-buttons-compact .btn-decline.selected{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn-label{font-weight:500;font-size:var(--font-size-md)}.btn-confirmation-text{font-size:var(--font-size-sm);opacity:.8;font-weight:400}.group-metadata-compact{display:none;max-height:48px;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm) 0;border-radius:var(--radius-lg);cursor:pointer;animation:fadeIn .2s ease-out}.group-page.metadata-collapsed .group-metadata-compact{display:flex}.metadata-compact-left{display:flex;align-items:center;gap:var(--space-sm);min-width:0;flex:1}.metadata-compact-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.metadata-compact-row{display:flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-primary)}.metadata-compact-row svg{color:var(--color-text-muted)}.flash{animation:flashHighlight 1.5s ease}@keyframes flashHighlight{0%{color:var(--color-accent);transform:scale(1.05)}to{color:inherit;transform:scale(1)}}.avatar-more{background:var(--color-bg-tertiary);color:var(--color-text-secondary);font-size:10px;font-weight:600}.map-page-container{height:100%;position:relative;display:flex;flex-direction:column}.map-legend{position:absolute;bottom:var(--space-md);left:var(--space-md);background:rgba(var(--color-bg-primary-rgb),.75);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);box-shadow:0 2px 8px var(--color-shadow);z-index:1000;display:flex;align-items:center;gap:var(--space-md);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(var(--color-border-rgb),.3);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.map-center-btn{position:absolute;bottom:var(--space-md);right:var(--space-md);width:44px;height:44px;background:rgba(var(--color-bg-primary-rgb),.9);border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #00000026;z-index:1000;transition:all .2s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.map-center-btn:hover{background:rgba(var(--color-bg-primary-rgb),1);color:var(--color-accent);box-shadow:0 4px 16px #0000002e}.map-center-btn:active{transform:scale(.92);box-shadow:0 1px 6px #0000001f}.map-center-btn svg{width:22px;height:22px}.map-legend-item{display:flex;align-items:center;gap:var(--space-xs)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.ready{background:#22c55e}.status-dot.later{background:#9ca3af}.status-dot.you{background:#3b82f6}.map-friend-popup{min-width:220px;font-family:var(--font-sans)}.map-friend-main{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);flex-wrap:nowrap}.map-friend-details{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.map-friend-name{font-weight:600;font-size:var(--font-size-md);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.map-friend-status-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.5px;align-self:flex-start;line-height:1}.map-friend-status-tag.ready{background-color:var(--color-accent-light);color:var(--color-accent)}.map-friend-status-tag.upcoming{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary)}.map-friend-meta{display:flex;flex-direction:column;gap:5px;padding-top:var(--space-sm);margin-top:2px}.map-friend-row{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:normal}.map-cluster-popup{display:flex;flex-direction:column;min-width:240px}.map-cluster-divider{height:1px;background-color:var(--color-border);margin:12px 0;width:100%}.leaflet-popup-content-wrapper{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important;border-radius:var(--radius-xl)!important;box-shadow:0 10px 40px #00000026,0 2px 10px #0000001a!important;border:1px solid var(--color-border)!important;overflow:hidden}.leaflet-popup-content{margin:var(--space-md)!important;font-size:var(--font-size-sm);line-height:1.5}.leaflet-popup-tip{background:var(--color-bg-primary)!important;border:1px solid var(--color-border)!important;box-shadow:0 2px 4px #00000014!important}.leaflet-popup-close-button{color:var(--color-text-muted)!important;font-size:20px!important;font-weight:400!important;width:28px!important;height:28px!important;padding:0!important;right:8px!important;top:8px!important;border-radius:var(--radius-full)!important;transition:background .2s ease!important}.leaflet-popup-close-button:hover{color:var(--color-text-primary)!important;background:var(--color-bg-tertiary)!important}.leaflet-container{font-family:var(--font-sans)}.leaflet-control-attribution{background:transparent!important;color:var(--color-text-primary)!important}.leaflet-control-attribution a{color:var(--color-text-primary)!important}.custom-marker,.user-marker{background:transparent!important;border:none!important}.leaflet-control-zoom{border:none!important;box-shadow:0 2px 8px var(--color-shadow)!important}.leaflet-control-zoom a{background:var(--color-bg-primary)!important;color:var(--color-text-primary)!important;border:none!important}.leaflet-control-zoom a:hover{background:var(--color-bg-secondary)!important}.leaflet-control-zoom-in{border-bottom:1px solid var(--color-border)!important;border-radius:var(--radius-md) var(--radius-md) 0 0!important}.leaflet-control-zoom-out{border-radius:0 0 var(--radius-md) var(--radius-md)!important}.group-map-modal{width:100%;height:100%;max-height:100%;max-width:100%;display:flex;flex-direction:column}.group-map-footer{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm) var(--space-md) calc(var(--space-sm) + env(safe-area-inset-bottom,0px))}.map-picker-quick-picks{display:flex;flex-direction:column;gap:var(--space-xs);width:100%}.map-picker-quick-picks__label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary)}.map-picker-quick-picks__list{display:flex;gap:var(--space-xs);overflow-x:auto;padding-bottom:2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.map-picker-quick-picks__list::-webkit-scrollbar{display:none}.map-picker-quick-picks__item{flex-shrink:0;white-space:nowrap}.map-picker-input-row{display:flex;gap:var(--space-sm);align-items:center;width:100%}.map-picker-input-row .input{flex:1;min-width:0}.map-picker-input-row .btn-icon-square{flex-shrink:0}.map-legend-compact{position:absolute;bottom:var(--space-sm);left:var(--space-sm);background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-md);display:flex;gap:var(--space-md);font-size:var(--font-size-xs);color:#fff;z-index:1000}.map-legend-compact .map-legend-item{display:flex;align-items:center;gap:4px}.map-legend-compact .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.map-legend-compact .status-dot.you{background:#3b82f6;border:1px solid white}.map-legend-compact .status-dot.member{background:#9ca3af;border:1px solid white}.map-legend-compact .status-dot.centroid{background:#6b7280;border:1px solid white}.map-legend-compact .status-dot.walk{background:var(--color-accent);border:1px solid white}.network-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md);position:sticky;top:0;background:var(--color-bg-primary);z-index:10}.network-tab{flex:1;padding:var(--space-md);text-align:center;font-weight:500;color:var(--color-text-muted);border:none;background:none;cursor:pointer;position:relative;transition:color .2s ease;font-size:var(--font-size-md)}.network-tab--active{color:var(--color-accent)}.network-tab--active:after{content:"";position:absolute;bottom:-1px;left:var(--space-lg);right:var(--space-lg);height:2px;background:var(--color-accent);border-radius:var(--radius-full)}.network-tab__badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:var(--font-size-xs);font-weight:600;margin-left:var(--space-xs);vertical-align:middle}.network-group-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .15s ease}.network-group-item:last-child{border-bottom:none}.network-group-item:active{background:var(--color-bg-secondary)}.network-group-item__color{width:4px;height:40px;border-radius:var(--radius-full);flex-shrink:0}.network-group-item__emoji{font-size:1.5rem;flex-shrink:0}.network-group-item__icon-image{width:30px;height:30px;display:block}.network-group-item__info{flex:1;min-width:0}.network-group-item__name{font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.network-group-item__meta{font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex;align-items:center;gap:var(--space-xs)}.network-group-item__chevron{color:var(--color-text-muted);flex-shrink:0;width:20px;height:20px}.network-group-item__actions{display:flex;align-items:center;gap:var(--space-sm)}.network-group-item__leave-btn,.network-group-item__toggle-btn{width:32px;height:32px;min-width:32px;min-height:32px;border-radius:var(--radius-md)}.network-group-item__action-spacer{width:32px;height:32px;min-width:32px;min-height:32px;flex-shrink:0}.network-group-item__hidden-indicator{color:var(--color-text-muted)}.network-groups__header{display:flex;justify-content:flex-end;margin-bottom:var(--space-sm)}.network-groups__edit-toggle{display:inline-flex;align-items:center;gap:var(--space-xs);border:1px solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-primary);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;line-height:1;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .15s ease;cursor:pointer}.network-groups__edit-toggle:active{transform:scale(.98)}.network-groups__edit-toggle--full{width:100%;justify-content:center;margin-bottom:var(--space-lg);border-radius:var(--radius-md);border:none}.network-groups__edit-toggle-icon{width:22px;height:22px;border-radius:var(--radius-full);display:inline-flex;align-items:center;justify-content:center}.network-groups__edit-toggle--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}@media(hover:hover){.network-groups__edit-toggle:hover{background:var(--color-bg-tertiary)}.network-groups__edit-toggle--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover)}}.network-group-item--dragging{opacity:.4}.network-group-item--drag-over{border-top:2px solid var(--color-accent)}.network-group-item__handle{color:var(--color-text-muted);flex-shrink:0;width:24px;height:24px;cursor:grab;transition:color .2s ease;touch-action:none}.network-group-item__handle:active{cursor:grabbing;color:var(--color-text-primary)}.fixed-group-invite{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-sm);border-left:3px solid var(--color-accent)}.fixed-group-invite__info{display:flex;flex-direction:column;flex:1;min-width:0}.fixed-group-invite__name{font-weight:600}.fixed-group-invite__from{font-size:var(--font-size-sm);color:var(--color-text-muted)}.fixed-group-invite__actions{display:flex;gap:var(--space-xs)}.network-create-group-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm)}.network-groups__bottom-spacer{height:calc(var(--bottom-nav-total-height) + 104px)}.context-tabs{display:flex;border-bottom:1px solid var(--color-border);background:var(--color-bg-primary);position:sticky;top:0;z-index:10}.context-tab{flex:1;padding:var(--space-sm) var(--space-md);text-align:center;font-weight:500;color:var(--color-text-muted);border:none;background:none;cursor:pointer;position:relative;transition:color .2s ease;font-size:var(--font-size-md);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.context-tab--active{color:var(--color-accent)}.context-tab--active:after{content:"";position:absolute;bottom:-1px;left:var(--space-lg);right:var(--space-lg);height:2px;background:var(--color-accent);border-radius:var(--radius-full)}.context-tab svg{width:18px;height:18px}.context-content{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.lobby-view{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.lobby-group{margin-bottom:var(--space-lg)}.lobby-group--highlighted{animation:lobby-group-highlight 2.2s ease-out}.lobby-group__header{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0;margin-bottom:var(--space-sm);border-left:3px solid var(--color-border);padding-left:var(--space-sm)}.lobby-group__emoji{font-size:var(--font-size-xl)}.lobby-category{margin-bottom:var(--space-md);padding-left:var(--space-sm)}.lobby-category__header{font-size:var(--font-size-md);font-weight:600;margin-bottom:var(--space-sm);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-sm)}.lobby-category__count{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:400}.lobby-users{display:flex;flex-wrap:wrap;gap:var(--space-md)}.lobby-user{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);width:64px;cursor:pointer}.lobby-user__avatar{position:relative}.lobby-user__name{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.lobby-empty{text-align:center;padding:var(--space-2xl);color:var(--color-text-muted)}.lobby-user--highlighted{animation:lobby-highlight-pulse 2s ease-out}@keyframes lobby-highlight-pulse{0%,15%{background:var(--color-accent-alpha, rgba(99, 102, 241, .2));border-radius:var(--radius-md);box-shadow:0 0 0 4px var(--color-accent-alpha, rgba(99, 102, 241, .15))}to{background:transparent;box-shadow:0 0 0 4px transparent}}@keyframes lobby-group-highlight{0%,18%{background:var(--color-accent-alpha, rgba(99, 102, 241, .16));border-radius:var(--radius-md);box-shadow:0 0 0 4px var(--color-accent-alpha, rgba(99, 102, 241, .14))}to{background:transparent;box-shadow:0 0 0 4px transparent}}@keyframes slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes flash{0%{color:var(--color-danger);opacity:.8;transform:scale(1.06)}10%{color:var(--color-danger);opacity:1;transform:scale(1.03)}to{color:inherit;opacity:1;transform:scale(1)}}.flash{animation:flash 3s cubic-bezier(.16,1,.3,1) forwards;will-change:color,transform,opacity}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-danger)}.text-accent{color:var(--color-accent)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-bold{font-weight:700}.font-medium{font-weight:500}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.w-full{width:100%}.mb-0{margin-bottom:0!important}.mb-xs{margin-bottom:var(--space-xs)!important}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;-moz-box-sizing:border-box;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;-webkit-transition:opacity .2s linear;-moz-transition:opacity .2s linear;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{-webkit-transform-origin:0 0;-ms-transform-origin:0 0;transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{-webkit-transition:none;-moz-transition:none;transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;-moz-box-sizing:border-box;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);-ms-transform:rotate(45deg);transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
