:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f6f9fb;--color-bg-tertiary: #eff2f5;--color-text-primary: #1a1a1a;--color-text-secondary: #666666;--color-text-muted: #888;--color-text-placeholder: #bbb;--color-text-inverted: #f0f6fc;--color-accent: #22c55e;--color-accent-light: #dcfce7;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-warning: #f59e0b;--color-info: #3b82f6;--color-border: #e0e0e0;--color-shadow: rgba(0, 0, 0, .1);--avatar-fallback-bg-mix: 30%;--avatar-fallback-fg-mix: 80%;--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-xxs: .625rem;--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: 52px;--bottom-nav-height: 52px;--bottom-safe-area: max(0px, var(--safe-area-inset-bottom));--bottom-nav-total-height: calc(var(--bottom-nav-height) + var(--bottom-safe-area));--top-header-total-height: calc(var(--top-header-height) + var(--safe-area-inset-top));--floating-action-button-height: 36px;--floating-action-dock-padding: 0px;--floating-action-dock-height: calc(var(--floating-action-button-height) + var(--floating-action-dock-padding) + var(--floating-action-dock-padding));--floating-action-button-bottom-padding: var(--space-md);--page-scroll-bottom-spacer: var(--space-md);--page-scroll-bottom-spacer-with-floating-action: calc(var(--floating-action-dock-height) + var(--floating-action-button-bottom-padding) + var(--space-md));--max-width: 480px;--max-width-narrow: 400px;--safe-area-inset-bottom: env(safe-area-inset-bottom, 0px);--safe-area-inset-top: env(safe-area-inset-top, 0px);--backdrop-filter-chrome: blur(16px) saturate(135%);--backdrop-filter-panel: blur(12px) saturate(122%);--backdrop-filter-compact: blur(8px) saturate(115%);--backdrop-filter-accent: var(--backdrop-filter-compact);--backdrop-filter-scrim: blur(4px);--backdrop-fill-chrome: color-mix(in srgb, var(--color-bg-primary) 80%, transparent);--backdrop-fill-panel: color-mix(in srgb, var(--color-bg-primary) 88%, transparent);--backdrop-fill-panel-strong: color-mix(in srgb, var(--color-bg-primary) 92%, transparent);--backdrop-fill-compact: color-mix(in srgb, var(--color-bg-primary) 80%, transparent);--backdrop-fill-modal: color-mix(in srgb, var(--color-bg-primary) 90%, transparent);--backdrop-fill-modal-strong: color-mix(in srgb, var(--color-bg-primary) 94%, transparent);--backdrop-fill-accent: color-mix(in srgb, var(--color-accent) 14%, var(--backdrop-fill-compact));--backdrop-fill-accent-strong: color-mix(in srgb, var(--color-accent) 24%, var(--backdrop-fill-compact));--backdrop-fill-accent-solid: color-mix(in srgb, var(--color-accent) 75%, var(--backdrop-fill-panel-strong));--backdrop-border-chrome: color-mix(in srgb, var(--color-border) 55%, transparent);--backdrop-border-panel: color-mix(in srgb, var(--color-border) 70%, transparent);--backdrop-border-compact: color-mix(in srgb, var(--color-border) 50%, transparent);--backdrop-border-modal: color-mix(in srgb, var(--color-border) 78%, transparent);--backdrop-shadow-panel: 0 14px 36px rgba(0, 0, 0, .18);--backdrop-shadow-compact: 0 4px 16px rgba(0, 0, 0, .14);--backdrop-shadow-modal: 0 20px 44px rgba(0, 0, 0, .24);--backdrop-scrim-soft-bg: rgba(0, 0, 0, .18);--backdrop-scrim-strong-bg: rgba(0, 0, 0, .38);--backdrop-primary: var(--backdrop-filter-panel);--primary-backdrop: var(--backdrop-filter-chrome);--backdrop-secondary: var(--backdrop-filter-compact);--button-hover-brightness: .95}:root[data-ios-safe-area-optimized=true]{--safe-area-inset-top: max(0px, calc(env(safe-area-inset-top, 0px) - 3px) );--safe-area-inset-bottom: max(0px, calc(env(safe-area-inset-bottom, 0px) - 3px) )}@media(prefers-color-scheme:dark){:root{--color-bg-primary: #0d1117;--color-bg-secondary: #131820;--color-bg-tertiary: #1d232b;--color-text-primary: #f0f6fc;--color-text-secondary: #8b949e;--color-text-muted: #8e96a1;--color-text-placeholder: #3e4651;--color-text-inverted: #1a1a1a;--color-accent: #22c55e;--color-accent-light: #166534;--color-danger: #f05e5e;--color-danger-light: #7f1d1d;--color-warning: #f5b30b;--color-info: #3b82f6;--color-border: #30363d;--color-shadow: rgba(0, 0, 0, .3);--button-hover-brightness: 1.1}}*,*: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% + var(--safe-area-inset-top));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;user-select:none;-webkit-user-select:none}#root{height:100vh;height:100dvh;min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}a{color:var(--color-accent);text-decoration:none}@media(hover:hover){a:hover{filter:brightness(1.1)}}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}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}::-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-group--indented{margin-left:0;padding-left:var(--space-sm)}.form-setting-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.form-setting-label{display:flex;align-items:center;gap:var(--space-sm);min-width: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:100dvh;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),var(--safe-area-inset-top));padding-bottom:max(var(--space-lg),var(--safe-area-inset-bottom))}.auth-container{width:100%;max-width:var(--max-width-narrow)}.page{display:flex;flex-direction:column;flex:1;min-height:0;height:100%;width:100%;--page-overlay-top-clearance: var(--top-header-total-height);--page-overlay-bottom-clearance: calc(var(--bottom-nav-total-height) + var(--page-scroll-bottom-spacer));--page-overlay-bottom-clearance-with-floating-action: calc(var(--bottom-nav-total-height) + var(--page-scroll-bottom-spacer-with-floating-action));overflow-x:hidden}.page.no-header-offset{--page-overlay-top-clearance: max(var(--space-sm), var(--safe-area-inset-top))}.page.no-bottom-nav{height:100%;--page-overlay-bottom-clearance: var(--page-scroll-bottom-spacer);--page-overlay-bottom-clearance-with-floating-action: var(--page-scroll-bottom-spacer-with-floating-action);overflow:visible}.page-flex{display:flex;flex-direction:column;height:100%;min-width:0;min-height:0;overflow-x:hidden}.page-fixed{flex-shrink:0}.page-fixed--chrome-offset{padding-top:var(--page-overlay-top-clearance)}.page-scroll{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;-webkit-overflow-scrolling:touch;padding-top:var(--page-overlay-top-clearance);padding-bottom:var(--page-overlay-bottom-clearance);scroll-padding-top:var(--page-overlay-top-clearance);scroll-padding-bottom:var(--page-overlay-bottom-clearance)}.page-scroll--after-fixed{padding-top:0;scroll-padding-top:var(--space-md)}.page-scroll.page-scroll--with-floating-action{padding-bottom:var(--page-overlay-bottom-clearance-with-floating-action);scroll-padding-bottom:var(--page-overlay-bottom-clearance-with-floating-action)}.top-header{position:fixed;top:0;left:0;right:0;height:var(--top-header-total-height);padding-top:var(--safe-area-inset-top);background:var(--backdrop-fill-chrome);backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);border-bottom:1px solid var(--backdrop-border-chrome);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{--page-overlay-top-clearance: var(--top-header-total-height)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-total-height);padding-bottom:var(--bottom-safe-area);background:var(--backdrop-fill-chrome);backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);border-top:1px solid var(--backdrop-border-chrome);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{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xs);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-avatar{transition:box-shadow .12s ease-out}.bottom-nav-item.active .bottom-nav-avatar{box-shadow:0 0 0 2px var(--color-accent)}.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-avatar{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;background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn:active{transform:scale(.97)}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-secondary{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}.btn-ghost{background-color:transparent}.btn-text-danger{color:var(--color-danger)}@media(hover:hover){.btn:hover:not(:disabled){filter:brightness(var(--button-hover-brightness))}.btn-ghost:hover:not(:disabled){background-color:transparent;filter:none}}.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{filter:brightness(var(--button-hover-brightness))}.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:color-mix(in srgb,var(--color-accent) 10%,transparent)}.btn-accept.selected:hover{filter:brightness(var(--button-hover-brightness))}.btn-decline:not(.selected):hover:not(:disabled){background:color-mix(in srgb,var(--color-danger) 10%,transparent)}.btn-decline.selected:hover{filter:brightness(var(--button-hover-brightness))}}.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-circle{width:36px;height:36px;min-width:36px;min-height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;gap:0}.btn-icon-circle:active:not(:disabled){transform:scale(.92)}.btn-icon-circle 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:color-mix(in srgb,var(--color-accent) var(--avatar-fallback-bg-mix, 50%),var(--color-bg-primary));display:flex;align-items:center;justify-content:center;font-weight:600;color:color-mix(in srgb,var(--color-accent) var(--avatar-fallback-fg-mix, 80%),var(--color-text-primary));flex-shrink:0}.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--no-base-outline{box-shadow:none}.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 var(--color-accent)!important;box-sizing:border-box;--avatar-status-glow-min: 0 0 6px 1px color-mix(in srgb, var(--color-accent) 55%, transparent);--avatar-status-glow-max: 0 0 12px 3px color-mix(in srgb, var(--color-accent) 75%, transparent);animation:avatar-status-pulse 1.5s ease-in-out infinite}.avatar-scheduled,.avatar-stack--muted .avatar.avatar-scheduled{border:2px solid var(--color-text-muted)!important;box-sizing:border-box;animation:none}.avatar--ring-custom{border:2px solid var(--avatar-ring-color, var(--color-text-muted))!important;box-sizing:border-box;animation:none}.avatar--ring-glow{--avatar-status-glow-min: 0 0 6px 1px color-mix(in srgb, var(--avatar-glow-color, var(--color-accent)) 55%, transparent);--avatar-status-glow-max: 0 0 12px 3px color-mix(in srgb, var(--avatar-glow-color, var(--color-accent)) 75%, transparent);animation:avatar-status-pulse 1.5s ease-in-out infinite}@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-primary);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:calc(-1 * var(--space-sm));border:2px solid var(--color-bg-primary)}.avatar-stack .avatar:first-child{margin-left:0}.avatar-stacked{margin-left:calc(-1 * var(--space-sm));border:2px solid var(--color-bg-primary)}.avatar-stacked:first-child{margin-left:0}.avatar-more{font-size:var(--font-size-xs);background:var(--avatar-overflow-bg, var(--color-bg-tertiary));color:var(--avatar-overflow-fg, var(--color-text-secondary));border-color:var(--avatar-overflow-border, var(--color-bg-primary))}.avatar-location-badge{position:absolute;left:var(--avatar-location-badge-anchor);top:var(--avatar-location-badge-anchor);transform:translate(-50%,-50%);width:var(--avatar-location-badge-size);height:var(--avatar-location-badge-size);background:var(--avatar-location-badge-bg-color);border:var(--avatar-location-badge-border-width) solid var(--avatar-location-badge-border-color);border-radius:50%;box-shadow:0 1px 4px #0003;z-index:2}.avatar-stack--muted .avatar{opacity:.6;filter:grayscale(40%)}.avatar-accepted{border:2px solid var(--color-accent)!important;box-sizing:border-box;animation:none}.avatar-declined{border:2px solid var(--color-danger)!important;box-sizing:border-box;animation:none}.avatar--tinted,.avatar--group-tinted{background-color:color-mix(in srgb,var(--avatar-tint-color, var(--color-accent)) var(--avatar-fallback-bg-mix, 50%),var(--color-bg-primary));color:color-mix(in srgb,var(--avatar-tint-color, var(--color-accent)) var(--avatar-fallback-fg-mix, 80%),var(--color-text-primary))}.group-avatar{position:relative;display:inline-flex;border-radius:var(--radius-full);overflow:visible}.group-avatar>.avatar{background-color:color-mix(in srgb,var(--group-ring-color, var(--color-accent)) var(--avatar-fallback-bg-mix, 50%),var(--color-bg-primary));color:color-mix(in srgb,var(--group-ring-color, var(--color-accent)) var(--avatar-fallback-fg-mix, 80%),var(--color-text-primary));box-shadow:none}.group-avatar--scheduled>.avatar{box-shadow:0 0 0 2px var(--color-text-muted);animation:none}.group-avatar--ready>.avatar{box-shadow:0 0 0 2px var(--group-ring-color, var(--color-accent));animation:none}.group-avatar--accepted>.avatar{box-shadow:0 0 0 2px var(--color-accent);animation:none}.group-avatar--declined>.avatar{box-shadow:0 0 0 2px var(--color-danger);animation:none}.group-avatar-stack{display:flex;align-items:center;overflow:visible;padding:var(--space-xs);margin:calc(-1 * var(--space-xs))}.group-avatar-stack>.group-avatar{margin-left:calc(-1 * var(--space-sm))}.group-avatar-stack>.avatar{margin-left:calc(-1 * var(--space-sm));border:2px solid var(--color-bg-primary);opacity:1}.group-avatar-stack>.group-avatar:first-child{margin-left:0}.group-avatar-stack>.avatar:first-child{margin-left:0}.group-avatar-stack>.group-avatar>.avatar{border:2px solid var(--color-bg-primary);opacity:1}.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{padding-left:var(--space-sm);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:var(--space-md);padding-left:0;scrollbar-width:none;scrollbar-color:var(--color-border) transparent;-webkit-overflow-scrolling:touch}.context-greeter__mode-row--flat{padding-left:var(--space-md);padding-right:var(--space-md)}.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;flex-shrink:0;min-width:0}.context-greeter__pill-anchor{--context-greeter-pill-height: 44px;--context-greeter-label-height: 13.2px ;position:relative;display:inline-flex;flex-direction:column;align-items:center;width:max-content;max-width:100%;padding-bottom:calc(var(--context-greeter-label-height) + var(--space-xs))}.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:var(--context-greeter-pill-height, 44px);box-sizing:border-box;padding:2px;padding-left:var(--space-sm);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__emoji-btn{border:none;background:transparent;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;line-height:1;width:var(--context-greeter-avatar-size, 32px);height:var(--context-greeter-avatar-size, 32px)}.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__emoji .group-emoji__icon--legacy{transform:scale(1.25)}.context-greeter__avatars{--context-greeter-avatar-size: 32px;display:flex;align-items:center;height:var(--context-greeter-avatar-size);margin-left:var(--space-xs)}.context-greeter__empty-dash{margin-left:var(--space-sm);margin-right:13px;font-weight:700;color:var(--color-text-muted);opacity:.5}.context-greeter__label{position:absolute;top:calc(var(--context-greeter-pill-height, 44px) + var(--space-xs));left:0;width:100%;display:block;font-size:11px;line-height:1.2;color:var(--color-text-secondary);font-weight:500;max-width:100%;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)}.badge-secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary)}.alert{padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.alert-warning{background-color:color-mix(in srgb,var(--color-warning) 20%,transparent);color:color-mix(in srgb,var(--color-warning) 80%,black);border:1px solid color-mix(in srgb,var(--color-warning) 50%,transparent)}.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;background:url(/icons/icon-animated-fast.gif) center / contain no-repeat;border:none;border-radius:var(--radius-full)}.spinner-small{width:20px;height:20px;background:url(/icons/icon-animated-fast.gif) center / contain no-repeat;border:none;border-radius:var(--radius-full)}.loading-container{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}@media(prefers-reduced-motion:reduce),(forced-colors:active){.loading-spinner,.spinner-small{background:none;border:2px solid var(--color-border);border-top-color:var(--color-accent);animation:spin .8s linear infinite}}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;inset:0;background:var(--backdrop-scrim-strong-bg);display:flex;align-items:center;justify-content:center;z-index:2000;backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim);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,.confirm-modal__actions,.update-modal__actions,.time-picker-modal .modal-footer{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm)}.modal-actions{margin-top:var(--space-lg)}.modal-actions .btn,.confirm-modal__actions .btn,.update-modal__actions .btn,.time-picker-modal .modal-footer .btn{width:100%;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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{padding:var(--space-md) var(--space-md);border-top:1px solid var(--color-border)}.time-picker-modal{width:280px;max-width:90vw}.time-picker-modal .modal-header{padding:var(--space-md);padding-bottom:var(--space-xs)}.time-picker-modal .modal-body{padding:var(--space-sm) var(--space-md) var(--space-md);display:flex;justify-content:center;align-items:center}.time-picker-modal .modal-footer{padding:var(--space-md) var(--space-md) var(--space-md);border-top:1px solid var(--color-border);background-color:var(--color-bg-primary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.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)}.update-modal__content{display:flex;flex-direction:column;gap:var(--space-md)}.update-modal__message{margin:0;color:var(--color-text-secondary)}.update-modal__versions{display:flex;gap:var(--space-md);justify-content:space-between;padding:var(--space-sm);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.update-modal__version-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.update-modal__version-value{font-weight:600;font-size:var(--font-size-lg)}.update-modal__version-value--new{color:var(--color-accent)}.update-modal__arrow{display:flex;align-items:center;color:var(--color-accent)}.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}.time-wheel-picker-modern.is-disabled{opacity:.6;pointer-events:none}.friend-info-popup-overlay{position:fixed;inset:0;background:var(--backdrop-scrim-soft-bg);z-index:9998;backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim)}.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)}}.group-pill{max-width:100%}.group-pill--interactive{appearance:none;cursor:pointer;font:inherit;text-align:left;transition:transform .15s ease,background-color .15s ease,border-color .15s ease}.group-pill--interactive:hover{background:color-mix(in srgb,var(--notification-group-color) 18%,var(--color-bg-secondary));border-color:color-mix(in srgb,var(--notification-group-color) 46%,var(--color-border))}.group-pill--interactive:active{transform:translateY(1px)}.group-pill--interactive:focus-visible{outline:2px solid color-mix(in srgb,var(--notification-group-color) 52%,var(--color-accent));outline-offset:2px}.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}.toast{--toast-accent: var(--color-accent);position:fixed;bottom:calc(var(--bottom-nav-total-height) + var(--space-lg));left:50%;transform:translate(-50%);max-width:min(90%,420px);display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-lg);background:var(--toast-accent);box-shadow:0 4px 12px #0003;color:#fff;font-size:var(--font-size-sm);font-weight:500;text-align:center;animation:slideUp .3s ease;z-index:3000}.toast--has-action{padding-right:var(--space-sm)}.toast--success{--toast-accent: var(--color-accent)}.toast--error{--toast-accent: var(--color-danger)}.toast--warning{--toast-accent: var(--color-warning)}.toast--info{--toast-accent: var(--color-info)}.toast__message{flex:1;min-width:0}.toast__action{background:#fff3;color:#fff;border:none;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);font-weight:600;cursor:pointer;font-size:var(--font-size-sm);white-space:nowrap;transition:background-color .2s,border-color .2s}.toast__action:hover{background:#ffffff4d}.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)}.card{padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:.5px .5px 5px #0000001a,inset .2px .2px 2.5px .1px #ffffff26}.profile-card{width:100%;background-color:var(--color-bg-primary);padding:var(--space-xl);border-radius:var(--radius-lg)}.profile-card__avatar{margin:0 auto var(--space-md);width:80px;height:80px;font-size:var(--font-size-2xl)}.profile-card__avatar-stack{position:relative;display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-md)}.profile-card__avatar-button{display:block;margin:0 auto;padding:0;border:none;background:transparent;border-radius:var(--radius-full);cursor:zoom-in}.profile-card__avatar-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.profile-card__stats-badge{margin-top:calc(var(--space-sm) * -1);display:inline-flex;align-items:center;gap:var(--space-xs);padding:6px 8px;border-radius:var(--radius-full);background:linear-gradient(135deg,color-mix(in srgb,var(--color-bg-primary) 92%,var(--color-accent)),color-mix(in srgb,var(--color-bg-secondary) 82%,var(--color-accent)));box-shadow:0 10px 22px #0000001f;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.profile-card__stats-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 8px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-bg-primary) 86%,transparent);color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:1}.profile-card__avatar-viewer-overlay{position:fixed;inset:0;z-index:2100;display:flex;align-items:center;justify-content:center;padding:var(--space-xl);background:var(--backdrop-scrim-strong-bg);backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim)}.profile-card__avatar-viewer-content{display:flex;align-items:center;justify-content:center}.profile-card__avatar-viewer-image{width:min(72vw,300px);height:min(72vw,300px);max-width:min(72vh,300px);max-height:min(72vh,300px);font-size:clamp(var(--font-size-2xl),9vw,5rem);box-shadow:0 16px 40px #0000004d}.profile-card__avatar-viewer-fallback{padding:var(--space-lg);text-align:center;line-height:1.25;font-size:clamp(var(--font-size-sm),3.4vw,var(--font-size-lg));font-weight:700}.profile-card__avatar-viewer-close{position:absolute;top:max(var(--space-lg),var(--safe-area-inset-top));right:max(var(--space-lg),var(--safe-area-inset-right));width:36px;height:36px;border-radius:var(--radius-full);border:none;background:var(--backdrop-fill-compact);backdrop-filter:var(--backdrop-filter-compact);-webkit-backdrop-filter:var(--backdrop-filter-compact);border:1px solid var(--backdrop-border-compact);color:var(--color-text-primary);font-size:var(--font-size-xl);line-height:1;cursor:pointer}.profile-card__avatar-viewer-close:hover{background:var(--backdrop-fill-panel-strong)}.profile-card__name{font-size:var(--font-size-xl);margin-bottom:var(--space-xs);font-weight:600}.profile-card__location{color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--space-xs)}.profile-card__info{padding:var(--space-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);white-space:pre-wrap}.profile-card__section{margin-bottom:var(--space-lg)}.profile-card__section-title{margin-bottom:var(--space-sm);font-weight:600}.profile-card__group-list{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-xs)}.profile-card__group-row{display:inline-flex;align-items:center;justify-content:flex-start;gap:0;min-width:0;max-width:100%;flex:0 1 auto}.profile-card__group-row .group-pill{min-width:0;flex:0 1 auto;position:relative;z-index:1;min-height:28px}.profile-card__group-stats{display:inline-flex;flex-direction:column;align-items:stretch;gap:2px;margin-left:-8px;padding:4px 6px 4px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--backdrop-border-compact) 75%,transparent);background:color-mix(in srgb,var(--color-bg-secondary) 76%,transparent);color:var(--color-text-secondary);font-size:8px;line-height:1;box-shadow:0 2px 8px #0000000a;min-height:28px}.profile-card__group-stat{display:grid;grid-template-columns:10px auto;align-items:center;gap:2px}.profile-card__group-stat>span[aria-hidden=true]{display:inline-flex;align-items:center;justify-content:center;filter:grayscale(1) saturate(.25)}.search-input-wrapper{position:relative;flex:1}.search-clear-btn{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);background:transparent;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:transparent;color:var(--color-text-primary)}.swipeable-content{background-color:var(--color-bg-primary);transition:background-color .2s ease}@media(hover:hover){.list-item--interactive:hover .swipeable-content{background-color:var(--color-bg-secondary)}}.group-list-item{padding:0;cursor:pointer}.group-list-item__content{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);gap:var(--space-sm);width:100%;overflow:visible;transition:background-color .2s ease}.group-list-item:active .group-list-item__content{background-color:var(--color-bg-secondary)}.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;display:flex;align-items:center;gap:6px;min-width:0;max-width:100%}.group-list-item__place{font-size:var(--font-size-sm);color:var(--color-text-muted);display:flex;align-items:center;gap:6px;min-width:0;max-width:100%;text-align:left}.group-list-item__time-text,.group-list-item__place-text{display:block;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-list-item__line-indicator{width:3px;min-width:3px;height:16px;border-radius:var(--radius-full);flex-shrink:0;background-color:transparent}.group-list-item__color{width:3px;height:40px;border-radius:var(--radius-full);flex-shrink:0}.group-list-item__emoji{flex-shrink:0;font-size:1.6rem;line-height:1;width:40px;height:40px;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;transform:translate(0)}.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-sm);flex-shrink:0}.swipeable-list-item{position:relative;overflow:hidden}.list{display:flex;flex-direction:column}.list-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-xs);transition:background-color .15s ease}.list-item[style*=--item-accent]{border-left:3px solid var(--item-accent)}.list-item--interactive{cursor:pointer}.list-item--interactive:active{background:var(--color-bg-secondary)}@media(hover:hover){.list-item--interactive:hover{background-color:var(--color-bg-secondary)}}.list-item__leading{flex-shrink:0}.list-item__body{flex:1;min-width:0;overflow:hidden}.list-item__primary{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:var(--space-xs)}.list-item__secondary{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item__trailing{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.floating-save-btn-container{position:fixed;bottom:var(--bottom-nav-total-height);left:0;right:0;padding:calc(var(--space-sm) + var(--space-xs));max-width:var(--max-width);margin:0 auto;z-index:999;pointer-events:none}.floating-save-btn-container:before{content:"";position:absolute;inset:-7px;border-radius:calc(var(--radius-xl) + var(--space-sm)) calc(var(--radius-xl) + var(--space-sm)) 0 0;background:linear-gradient(180deg,color-mix(in srgb,var(--backdrop-fill-panel) 0%,transparent),color-mix(in srgb,var(--backdrop-fill-panel) 18%,transparent) 24%,color-mix(in srgb,var(--backdrop-fill-panel) 54%,transparent),color-mix(in srgb,var(--backdrop-fill-panel) 92%,transparent));backdrop-filter:blur(18px) saturate(132%);-webkit-backdrop-filter:blur(18px) saturate(132%);mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.7) 28%,#000000 58%,#000000 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,.7) 28%,#000000 58%,#000000 100%);pointer-events:none}.floating-save-btn-bar{display:flex;gap:var(--space-sm);width:100%;pointer-events:none}.floating-save-btn{flex:1;min-height:var(--floating-action-button-height);padding:0 var(--space-md);border-radius:var(--radius-md);border:none;font-size:var(--font-size-md);font-weight:500;cursor:pointer;transition:background-color .16s ease,color .16s ease,box-shadow .16s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);box-shadow:0 2px 6px #0000001a,0 10px 24px #00000029;pointer-events:auto;backdrop-filter:var(--backdrop-filter-compact);-webkit-backdrop-filter:var(--backdrop-filter-compact);background-color:color-mix(in srgb,var(--color-bg-tertiary) 88%,var(--backdrop-fill-panel));color:var(--color-text-primary);-webkit-tap-highlight-color:transparent}.floating-save-btn svg{flex-shrink:0}.floating-save-btn--secondary{background-color:color-mix(in srgb,var(--color-bg-tertiary) 88%,var(--backdrop-fill-panel));color:var(--color-text-primary)}.floating-save-btn--primary{background-color:color-mix(in srgb,var(--color-accent) 92%,var(--backdrop-fill-panel-strong));color:#fff}.floating-save-btn:focus{outline:none}.floating-save-btn:focus-visible{box-shadow:0 2px 6px #0000001a,0 10px 24px #00000029,0 0 0 2px color-mix(in srgb,var(--color-bg-primary) 92%,transparent),0 0 0 4px color-mix(in srgb,var(--color-accent) 72%,transparent)}.floating-save-btn:disabled{cursor:not-allowed;background-color:color-mix(in srgb,var(--color-bg-tertiary) 88%,var(--backdrop-fill-panel));color:var(--color-text-placeholder);box-shadow:0 2px 6px #0000001a,0 10px 24px #00000029}.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);background:transparent;color:var(--color-text-secondary);transition:color .2s ease,filter .2s ease;cursor:pointer}.notification-bell:hover{color:var(--color-text-primary);background:transparent;filter:brightness(var(--button-hover-brightness))}.notification-bell.is-open{color:var(--color-accent);background:transparent}.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:var(--color-text-inverted);font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.notification-panel-backdrop{position:fixed;inset:0;z-index:1900;border:none;background:var(--backdrop-scrim-soft-bg);backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim);cursor:default}.notification-panel{position:fixed;z-index:1951;width:min(360px,calc(100vw - 24px));max-height:min(72vh,480px);display:flex;flex-direction:column;border-radius:var(--radius-xl);border:1px solid var(--backdrop-border-panel);background:linear-gradient(180deg,var(--backdrop-fill-panel-strong),var(--backdrop-fill-panel));backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);box-shadow:var(--backdrop-shadow-panel);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 var(--backdrop-border-compact);flex-shrink:0}.notification-panel-title-wrap{display:inline-flex;align-items:center;gap:var(--space-sm);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 var(--backdrop-border-panel);border-radius:var(--radius-full);background:var(--backdrop-fill-compact);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:600;line-height:1;padding:var(--space-xs) var(--space-sm);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:var(--backdrop-fill-panel-strong)}.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-md);padding:var(--space-sm) var(--space-md);cursor:pointer;text-align:left;border-bottom:1px solid color-mix(in srgb,var(--color-border) 60%,transparent);transition:background-color .2s ease}.notification-item[role=button]{outline:none}.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;margin-top:var(--space-sm)}.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:var(--space-xxs)}.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%;min-height:24px;box-sizing:border-box;border-radius:var(--radius-full);border:1px solid var(--backdrop-border-compact);background:var(--backdrop-fill-compact);color:var(--color-text-secondary);font-size:11px;font-weight:600;line-height:1;padding:3px 6px}.notification-chip--actor{padding:3px 8px 3px 3px}.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;margin-right:-1px}.notification-chip-default-logo{margin-right:-1px;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;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-item-body-wrap{display:flex;align-items:baseline;min-width:0;gap:0}.notification-item-body-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.35;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.notification-item-body-text.is-expanded{white-space:normal;overflow:visible;text-overflow:unset}.notification-item-more{color:var(--color-accent);font-size:var(--font-size-sm);font-weight:600;line-height:1.35;flex-shrink:0;cursor:pointer;border:none;background:none;padding:0;margin-left:var(--space-xxs);white-space:nowrap}.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{position:fixed;top:0;left:0;right:0;z-index:2050;pointer-events:none;padding:calc(var(--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;border-radius:var(--radius-xl);border:1px solid var(--backdrop-border-panel);background:linear-gradient(180deg,var(--backdrop-fill-panel-strong),var(--backdrop-fill-panel));backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);box-shadow:var(--backdrop-shadow-panel);padding:0;cursor:pointer;transition:transform .2s ease-out,opacity .2s ease-out}.notification-banner__card.is-swiping{transition:none}.notification-item--banner{border-bottom:none;padding:var(--space-sm) var(--space-md);background:transparent}.notification-item--banner:hover,.notification-item--banner.unread,.notification-item--banner.unread:hover{background:transparent}.notification-item--banner .notification-item-icon{width:36px;height:36px;margin-top:0}.notification-item--banner .notification-leading-emoji{font-size:17px}.notification-item--banner .notification-item-content{gap:var(--space-xxs)}.notification-item--banner .notification-item-title{font-weight:700}.notification-item--banner .notification-item-meta{margin-top:var(--space-xxs)}.notification-item--banner .notification-item-body{margin-top:0}.nav-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.nav-badge{position:absolute;top:-3px;right:-5px;min-width:14px;height:14px;padding:0 3px;border-radius:var(--radius-full);background-color:var(--color-danger);color:var(--color-text-inverted);font-size:10px;font-weight:900;display:flex;align-items:center;justify-content:center;line-height:1}.nav-badge-dot{position:absolute;top:-3px;right:-5px;width:14px;height:14px;border-radius:var(--radius-full);background-color:var(--color-danger)}@media(max-width:480px){.notification-panel{right:calc(var(--space-xs) * -1)}}.message-context-overlay{--message-context-motion-duration: .2s;--message-context-motion-ease: cubic-bezier(.21, .61, .35, 1);position:fixed;inset:0;z-index:10000;opacity:0;transition:opacity .16s ease;pointer-events:none}.message-context-overlay.is-visible{opacity:1;pointer-events:auto}.message-context-backdrop{position:absolute;inset:0;background:transparent;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0);transition:background .18s ease,backdrop-filter .18s ease,-webkit-backdrop-filter .18s ease}.message-context-overlay.is-visible .message-context-backdrop{background:var(--backdrop-scrim-soft-bg);backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim)}.message-context-cluster{position:fixed;z-index:10001;transition:transform var(--message-context-motion-duration) var(--message-context-motion-ease);will-change:transform}.message-context-cluster.no-position-transition{transition:none!important}.message-context-stack{display:flex;flex-direction:column;gap:var(--space-sm)}.message-context-cluster.align-left .message-context-stack{align-items:flex-start}.message-context-cluster.align-right .message-context-stack{align-items:flex-end}.message-context-top{border-radius:var(--radius-lg);overflow:hidden;background:var(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);box-shadow:var(--backdrop-shadow-panel)}.message-context-quick-row{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:6px}.message-context-emoji-btn{flex:1 1 0;min-width:0;height:34px;border:none;border-radius:999px;background:transparent;color:var(--color-text-primary);font-size:18px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background-color .12s ease,transform .12s ease}.message-context-emoji-btn:hover{background:transparent;filter:brightness(1.08)}.message-context-emoji-btn:active{transform:scale(.95)}.message-context-emoji-btn.is-active{background:color-mix(in srgb,var(--color-accent) 20%,transparent)}.message-context-emoji-btn--special{font-size:20px}.message-context-expanded{height:0;overflow:hidden;border-top:1px solid transparent;transition:height var(--message-context-motion-duration) var(--message-context-motion-ease),border-top-color var(--message-context-motion-duration) var(--message-context-motion-ease)}.message-context-expanded.is-open{border-top-color:color-mix(in srgb,var(--color-border) 65%,transparent)}.message-context-expanded-inner{width:100%}.message-context-expanded .EmojiPickerReact{width:100%!important;border:none!important;border-radius:0!important;background:transparent!important;--epr-category-label-bg-color: color-mix(in srgb, var(--color-bg-primary) 88%, transparent) !important}.message-context-expanded .EmojiPickerReact *{--epr-bg-color: transparent !important;--epr-hover-bg-color: transparent !important}.message-context-expanded .EmojiPickerReact .epr-body,.message-context-expanded .EmojiPickerReact .epr-main,.message-context-expanded .EmojiPickerReact .epr-emoji-category-content,.message-context-expanded .EmojiPickerReact .epr-header,.message-context-expanded .EmojiPickerReact .epr-search-container,.message-context-expanded .EmojiPickerReact .epr-category-nav,.message-context-expanded .EmojiPickerReact .epr-preview{background:transparent!important}.message-context-expanded .EmojiPickerReact .epr-emoji-category-label{background:var(--message-context-category-label-bg, var(--epr-category-label-bg-color))!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;color:var(--color-text-secondary)!important;position:static!important;top:auto!important;z-index:auto!important}.message-context-message-lift{filter:none}.message-context-highlight-message{pointer-events:none;box-shadow:0 10px 24px #00000038;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.message-context-highlight-message.chat-message.own{backdrop-filter:none;-webkit-backdrop-filter:none;background:color-mix(in srgb,var(--color-accent) 80%,var(--color-bg-primary))}.message-context-highlight-message .vote-message,.message-context-highlight-message .vote-message__value{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.message-context-actions{background:var(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);border-radius:12px;overflow:hidden;box-shadow:var(--backdrop-shadow-panel)}.message-context-action-btn{display:flex;align-items:center;gap:12px;width:100%;border:none;background:transparent;color:var(--color-text-primary);text-align:left;font-size:14px;font-weight:500;padding:12px 16px;cursor:pointer;transition:background-color .12s ease}.message-context-action-btn:hover{background:transparent;filter:brightness(1.08)}.message-context-action-btn.danger{color:var(--color-danger)}.message-context-action-btn.danger:hover{background:transparent}.context-menu-source-hidden{opacity:0;pointer-events:none;transition:opacity .5s ease}.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}.autocomplete-popup{position:absolute;bottom:100%;left:0;right:0;margin-bottom:var(--space-xs);background:var(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);border:1px solid var(--backdrop-border-panel);border-radius:var(--radius-lg);box-shadow:var(--backdrop-shadow-panel);max-height:220px;overflow-y:auto;z-index:1001;display:flex;flex-direction:column;animation:autocomplete-fade-in .2s cubic-bezier(.16,1,.3,1);--mention-color-l: 45%}@keyframes autocomplete-fade-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.autocomplete-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);cursor:pointer;transition:all .15s ease;border-bottom:1px solid color-mix(in srgb,var(--color-border) 30%,transparent);-webkit-user-select:none;user-select:none}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item.selected{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.autocomplete-item:not(.selected):active{background:color-mix(in srgb,var(--color-accent) 20%,transparent)}.autocomplete-item.selected:active,.autocomplete-item.selected:focus,.autocomplete-item.selected:focus-visible{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.autocomplete-item-text{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.autocomplete-empty{padding:var(--space-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);font-style:italic}.autocomplete-popup--mention{min-width:200px;max-width:280px;left:var(--mention-left, 0);right:auto}.autocomplete-popup::-webkit-scrollbar{width:4px}.autocomplete-popup::-webkit-scrollbar-track{background:transparent}.autocomplete-popup::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--color-text-muted) 20%,transparent);border-radius:var(--radius-full)}@media(prefers-color-scheme:dark){.autocomplete-popup{background:var(--backdrop-fill-panel);border:1px solid var(--backdrop-border-panel);box-shadow:var(--backdrop-shadow-panel);--mention-color-l: 65%}.autocomplete-item.selected{background:color-mix(in srgb,var(--color-accent) 25%,transparent)}.autocomplete-item.selected:active,.autocomplete-item.selected:focus,.autocomplete-item.selected:focus-visible{background:color-mix(in srgb,var(--color-accent) 25%,transparent)}}.modal-fullscreen{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:var(--radius-xl);display:flex;flex-direction:column;overflow:hidden}.modal-fullscreen .modal-header{padding-top:var(--space-md);padding-bottom:var(--space-sm)}@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-container .map-center-btn{right:var(--space-sm);bottom:var(--space-sm)}.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 color-mix(in srgb,var(--color-accent) 40%,transparent)}70%{box-shadow:0 0 0 6px color-mix(in srgb,var(--color-accent) 0%,transparent)}to{box-shadow:0 0 color-mix(in srgb,var(--color-accent) 0%,transparent)}}.timeline-widget{padding:var(--space-sm) var(--space-xs);margin-bottom:0;overflow:visible;position:relative;border-radius:var(--radius-md)}.timeline-header-row{display:flex;align-items:flex-end;position:relative;height:16px;margin-bottom:var(--space-xs)}.timeline-header-left{width:20px;flex-shrink:0}.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--rain{color:var(--color-info);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:var(--space-3xs) var(--space-xs);border-radius:var(--radius-sm);z-index:1}.timeline-scrub-area{position:relative;cursor:crosshair;touch-action:none}.timeline-grid-line{position:absolute;top:0;bottom:0;width:1px;background:var(--color-text-muted);opacity:.1;pointer-events:none;z-index:0}.timeline-now-line{position:absolute;top:0;bottom:0;width:2px;transform:translate(-1px);background-image:repeating-linear-gradient(to bottom,var(--color-accent) 0 4px,transparent 4px 7px);opacity:.75;pointer-events:none;z-index:4}.timeline-now-line--scrubbing{opacity:1}.timeline-sun-line{position:absolute;top:0;bottom:0;width:1px;border-left:1px dashed var(--color-text-muted);opacity:.25;pointer-events:none;z-index:1}.timeline-pill-area{position:relative;min-height:4px;margin-bottom:var(--space-xxs);z-index:2}.timeline-pill-group{position:absolute;left:0;right:0}.timeline-pill-group-track{position:absolute;inset:-3px;border:0;padding:0;margin:0;pointer-events:none;z-index:0;border-radius:var(--radius-lg);background:color-mix(in srgb,var(--track-color) 18%,transparent);mask-image:linear-gradient(to bottom,transparent 0%,black 20%,black 80%,transparent 100%),linear-gradient(to right,transparent 0%,black 25%,black 75%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0%,black 20%,black 80%,transparent 100%),linear-gradient(to right,transparent 0%,black 25%,black 75%,transparent 100%);mask-composite:intersect;-webkit-mask-composite:source-in}.timeline-pill-group-hitbox{position:absolute;top:0;bottom:0;border:0;padding:0;margin:0;background:transparent;cursor:pointer;z-index:1}.timeline-pill-row{position:absolute;left:0;right:0;pointer-events:none}.timeline-pill{position:absolute;top:0;border-radius:9999px;background:linear-gradient(90deg,var(--pill-color) 0%,color-mix(in srgb,var(--pill-color) 85%,transparent) 100%),var(--backdrop-fill-panel-strong);-webkit-backdrop-filter:var(--backdrop-filter-compact);backdrop-filter:var(--backdrop-filter-compact);display:flex;align-items:center;gap:1px;padding-left:2px;overflow:hidden;min-width:20px;z-index:1;transition:opacity .15s ease;pointer-events:none}.timeline-pill:hover{opacity:.85}.timeline-pill--own{box-shadow:inset -.1px -.1px 100px 1.5px color-mix(in srgb,white 50%,transparent)}.timeline-pill--collapsed{border-radius:9999px;padding:0;min-width:4px;background:linear-gradient(90deg,var(--pill-color) 0%,color-mix(in srgb,var(--pill-color) 85%,transparent) 100%),var(--backdrop-fill-panel-strong)}.timeline-pill__avatar{border-radius:50%;overflow:hidden;flex-shrink:0;background:color-mix(in srgb,var(--pill-color) 30%,var(--color-bg-secondary));display:flex;align-items:center;justify-content:center}.timeline-pill__avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.timeline-pill__avatar-initial{font-size:8px;font-weight:600;color:var(--color-text-secondary);line-height:1}.timeline-chart{width:100%;display:block;pointer-events:none}.timeline-rain-yaxis{position:absolute;right:0;bottom:0;width:32px;pointer-events:none;z-index:5}.timeline-yaxis-label{position:absolute;width:100%;text-align:center;transform:translateY(-50%);font-size:9px;color:var(--color-text-muted);opacity:.6}.timeline-popup{position:absolute;top:var(--space-lg);transform:translate(-50%,-100%);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 15px #0009;z-index:100;display:flex;flex-direction:row;height:96px;width:max-content;padding:var(--space-sm) var(--space-md);gap:0;pointer-events:none}.timeline-popup__left{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);width:24px;padding-right:var(--space-xs);border-right:1px solid var(--color-border)}.timeline-popup__content{display:flex;flex-direction:column;gap:var(--space-sm);padding-left:var(--space-sm);flex:1}.timeline-popup__line{display:flex;align-items:center;gap:var(--space-sm);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:var(--color-text-primary);font-size:11px}.timeline-popup__friends{font-weight:700;color:var(--color-accent);font-size:14px}.timeline-popup__temp{font-weight:500}.timeline-popup__rain{color:var(--color-info)}.avatar-stack--popup{margin-left:0;display:flex;height:28px;align-items:center}.timeline-weather-row{display:flex;position:relative;height:16px;margin-top:2px;padding:0 32px 0 20px}.timeline-weather-row--placeholder{opacity:.55}.timeline-weather-item{position:absolute;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-xs);font-size:11px;font-weight:700}.timeline-weather-temp{color:var(--color-text-muted)}.timeline-weather-placeholder{position:absolute;inset:0}.timeline-divider{height:1px;background:var(--color-border);margin:var(--space-xs) 32px var(--space-xs) 20px}.timeline-hours-row{display:flex;position:relative;height:14px;padding:0 32px 0 20px}.timeline-hours-row--no-weather{margin-top:0}.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-xs);gap:var(--space-md)}.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))}.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{display:flex;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){filter:brightness(1.1);color:var(--color-info)}.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){filter:brightness(1.1);color:var(--color-accent)}.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){color:var(--color-danger);filter:brightness(1.1)}.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-card .group-mode-badge,.invite-info-modal .group-mode-badge{background:var(--color-bg-secondary);border-color:var(--color-border);color:var(--color-text-muted)}.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;display:flex;flex-direction:column;overflow:hidden;padding:var(--space-sm) 0;min-height:0}.invite-modal__list .friend-multi-select{height:100%;min-height:0}.invite-modal__list .friend-multi-select__search-wrap,.invite-modal__list .friend-multi-select__section-label,.invite-modal__list .friend-multi-select__empty,.invite-modal__list .friend-multi-select__item{padding-left:var(--space-lg);padding-right:var(--space-lg)}.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{margin-top:0;padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.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-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(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);border:1px solid var(--backdrop-border-panel);border-radius:var(--radius-md);box-shadow:0 8px 18px #00000029;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-primary) 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-primary) 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}.schedule-time-column{gap:var(--space-sm)}.schedule-time-main-label{margin-top:calc(-1 * var(--space-sm));display:flex;align-items:center;justify-content:flex-start;gap:var(--space-xs)}.schedule-time-column__header{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);min-height:24px}.schedule-time-tabs{display:inline-flex;align-items:center;gap:2px;padding:var(--space-xs);width:140px;border-radius:var(--radius-md);background:var(--color-bg-tertiary)}.schedule-time-tab{flex:1;border:none;border-radius:calc(.75*var(--radius-md));background:transparent;color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.05em;padding:var(--space-xs) var(--space-sm);line-height:1.2;text-align:center;cursor:pointer}.schedule-time-tab--active{background:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:0 1px 2px var(--color-shadow)}.schedule-day-offset-tag{flex-shrink:0;font-size:10px;font-weight:700;line-height:1;padding:3px 6px;border-radius:var(--radius-full);color:var(--color-accent);border:1px solid color-mix(in srgb,var(--color-accent) 35%,transparent);background:color-mix(in srgb,var(--color-accent) 14%,transparent)}.group-carousel{position:relative;margin-bottom:var(--space-xs);z-index:10;--group-glow-duration: 1.5s;--group-carousel-title-height: 36px;--group-carousel-status-height: 62px;--group-carousel-status-lines: 2;--group-carousel-status-row-height: 22px;--group-carousel-status-row-gap: 2px;--group-carousel-status-content-height: 16px;--group-carousel-status-content-line-height: 1.15;--group-carousel-action-content-height: 32px;--group-carousel-action-padding-top: 0px;--group-carousel-gap-title-status: 0px;--group-carousel-gap-status-action: 4px;--group-carousel-border-width: 2px;--group-carousel-right-col-width: 58px;--group-carousel-col-gap: var(--space-sm);overflow:visible;margin-inline:calc(var(--space-md) * -1)}.group-carousel__track{display:flex;gap:var(--space-sm);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) + var(--space-sm));padding-bottom:calc(var(--space-xl) + var(--space-sm));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) - var(--space-sm))}.group-carousel__track::-webkit-scrollbar{display:none}.group-carousel__track--instant{scroll-behavior:auto}.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:calc(var(--space-md) - 2px) var(--space-md) var(--space-md) var(--space-md);background:var(--color-bg-primary);border:var(--group-carousel-border-width) solid var(--color-border);display:grid;--group-carousel-action-height: calc(var(--group-carousel-action-content-height) + var(--group-carousel-action-padding-top, 0px));--group-carousel-card-height: calc((var(--space-md) * 2) + (var(--group-carousel-border-width) * 1) + var(--group-carousel-title-height) + var(--group-carousel-gap-title-status) + var(--group-carousel-status-height) + var(--group-carousel-gap-status-action) + var(--group-carousel-action-height) - 2px);--group-carousel-status-grid-rows: repeat(var(--group-carousel-status-lines), var(--group-carousel-status-row-height));grid-template-rows:var(--group-carousel-title-height) var(--group-carousel-gap-title-status) var(--group-carousel-status-height) var(--group-carousel-gap-status-action) var(--group-carousel-action-height);row-gap:0;min-height:var(--group-carousel-card-height);height:var(--group-carousel-card-height);cursor:pointer;position:relative;overflow:visible;transition:border-color .2s ease,box-shadow .2s ease}.group-carousel__card--context-status{--group-carousel-status-lines: 1}.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:var(--space-xs);min-width:0;width:110%;justify-self:stretch}.group-carousel__title-row{display:flex;align-items:center;gap:var(--space-sm);width:100%;min-width:0;overflow:hidden}.group-carousel__members{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-carousel__name-wrap{display:flex;align-items:center;gap:var(--space-xs);min-width:0;max-width:100%;overflow:hidden}.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:var(--space-xs);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__emoji{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;font-size:2rem;line-height:1}.group-carousel__emoji-image{width:38px;height:38px;border-radius:12px;display:block;object-fit:contain}.group-carousel__emoji-image--legacy{border-radius:0;width:52px;height:52px}.group-carousel__members-count{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);font-size:14px;color:var(--color-text-muted);font-weight:600;width:auto;font-variant-numeric:tabular-nums}.group-carousel__members-count span{display:inline-block;text-align: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:var(--space-xxs);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;margin-left:0}.group-carousel__range-metric-icon svg{display:block}.group-carousel__range-metric-icon--warning{color:var(--color-warning)}.group-carousel__range-value{display:inline-block;text-align:center;font-variant-numeric:tabular-nums}.group-carousel__status-time,.group-carousel__status-activity-text,.group-carousel__members-count,.group-carousel__range-row{min-height:var(--group-carousel-status-content-height);line-height:var(--group-carousel-status-content-line-height)}.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:var(--color-warning)}.group-carousel__range-metric-tooltip--warning .tooltip-trigger:hover{color:color-mix(in srgb,var(--color-warning) 80%,black)}.group-carousel__name{display:block;font-size:var(--font-size-lg);font-weight:600;text-align:left;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:clip;width:100%;max-width:100%;min-width:0;flex:1 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:3;grid-column:1 / -1;display:block;font-size:var(--font-size-sm);color:var(--color-text-muted);min-width:0;width:100%;height:100%;overflow:hidden}.group-carousel__status-grid{display:grid;grid-template-columns:minmax(0,1fr) var(--group-carousel-right-col-width);grid-template-rows:var(--group-carousel-status-grid-rows);column-gap:var(--group-carousel-col-gap);row-gap:var(--group-carousel-status-row-gap);align-content:center;align-items:stretch;width:100%;height:100%}.group-carousel__status-cell{display:flex;height:100%;align-items:flex-end;min-height:var(--group-carousel-status-row-height);min-width:0;overflow:visible}.group-carousel__status-cell--time,.group-carousel__status-cell--activity{justify-self:start;width:100%}.group-carousel__status-cell--members,.group-carousel__status-cell--range{justify-self:center;justify-content:center;width:var(--group-carousel-right-col-width);min-width:var(--group-carousel-right-col-width)}.group-carousel__status-grid--status{grid-template-rows:var(--group-carousel-status-grid-rows)}.group-carousel__status-grid--status .group-carousel__status-cell--time{grid-row:1;align-items:center}.group-carousel__status-grid--status .group-carousel__status-cell--members{grid-column:2;grid-row:1;align-items:center}.group-carousel__status-grid--status .group-carousel__status-cell--activity,.group-carousel__status-grid--status .group-carousel__status-cell--range{display:none}.group-carousel__card--context-categorical .group-carousel__status-cell--time{grid-column:1;grid-row:1}.group-carousel__card--context-categorical .group-carousel__status-cell--activity{grid-column:1;grid-row:2}.group-carousel__card--context-categorical .group-carousel__status-cell--members{grid-column:2;grid-row:1 / span 2;align-items:center}.group-carousel__card--context-categorical .group-carousel__status-cell--range{display:none}.group-carousel__status-cell--placeholder{visibility:hidden}.group-carousel__status-cell--clickable{cursor:pointer;border-radius:var(--radius-sm);transition:background-color .15s ease}.group-carousel__status-cell--clickable:active{background-color:color-mix(in srgb,var(--color-text-muted) 12%,transparent)}.group-carousel__status-activity-text{display:block;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;font-size:var(--font-size-sm)}.group-carousel__invite-meta{display:flex;align-items:center;gap:6px;width:100%;min-width:0;overflow:hidden}.group-carousel__invite-label{flex-shrink:0;color:var(--color-text-muted);white-space:nowrap}.group-carousel__actor-pill{max-width:100%;min-width:0}.group-carousel__status-time{display:block;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.8}.group-carousel__actions{grid-row:5;grid-column:1 / -1;display:flex;align-items:stretch;gap:var(--space-sm);width:100%;height:100%;margin-top:0;padding-top:var(--group-carousel-action-padding-top, 0);box-sizing:border-box}.group-carousel__card:not(.group-carousel__card--active)>*{pointer-events:none}.group-carousel__actions .btn{flex:1;min-height:0;height:var(--group-carousel-action-content-height);align-self:flex-end}.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)) 85%,var(--color-bg-tertiary));color:var(--color-text-primary)}@media(hover:hover){.group-carousel__btn-primary:hover{color:#fff;box-shadow:0 4px 14px color-mix(in srgb,var(--group-color, var(--color-accent)) 35%,transparent)}.group-carousel__btn-stop:hover{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:none}.group-carousel__card--add:hover,.group-carousel__card--add:active{opacity:1;box-shadow:none}.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);will-change:transform;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 .22s cubic-bezier(.22,1,.36,1),opacity .22s cubic-bezier(.22,1,.36,1);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;transform:translate(.2px)}.pagination-dot__icon-image{width:14px;height:14px;border-radius:2px;display:block;transform:none}.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)}}.match-detail-modal{padding:0 var(--space-lg) var(--space-lg)}.match-detail-modal__header{padding:var(--space-lg) 0 var(--space-md)}.match-detail-modal__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm)}.match-detail-modal__date{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary)}.match-detail-modal__subtitle{display:flex;align-items:center;gap:var(--space-sm);margin-top:4px;flex-wrap:wrap}.match-detail-modal__time{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.match-detail-modal__section{padding:var(--space-sm) 0}.match-detail-modal__section:not(:last-child){border-bottom:1px solid var(--color-border)}.match-detail-modal__info{display:flex;flex-direction:column;gap:var(--space-xs)}.match-detail-modal__divider{height:1px;background:var(--color-border);margin-bottom:var(--space-xs)}.match-detail-modal__info-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.match-detail-modal__info-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.match-detail-modal__info-value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);text-align:right}.match-detail-modal__members-label{font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.match-detail-modal__members{display:flex;flex-direction:column;gap:var(--space-xs)}.match-detail-modal__member{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) 0}.match-detail-modal__member-name{flex:1;min-width:0;font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-detail-modal__member-status{flex-shrink:0;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted)}.match-detail-modal__member-status--accepted{color:var(--color-accent)}.match-detail-modal__member-status--declined{color:var(--color-error)}.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:-10px;bottom:-10px}.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);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.btn-ghost{background:transparent}.group-create__type-option--selected{border-color:var(--color-accent);background:var(--color-accent-light)}.group-create__type-option.btn-ghost.group-create__type-option--selected{background:var(--color-accent-light)}.group-create__type-option--selected:hover,.group-create__type-option--selected:focus,.group-create__type-option--selected:focus-visible,.group-create__type-option--selected:active{border-color:var(--color-accent);background:var(--color-accent-light);filter:none}.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;word-break:normal;overflow-wrap:normal;-webkit-hyphens:auto;hyphens:auto}.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-item--selected:hover,.group-create__member-item--selected:focus,.group-create__member-item--selected:focus-visible,.group-create__member-item--selected:active{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);position:relative;margin-top:calc(-1 * var(--safe-area-inset-top))}.group-settings-page .page-scroll{position:relative;overflow-x:hidden}.group-settings-page .page-scroll>.container{position:relative;padding-top:calc(var(--space-md) + var(--safe-area-inset-top));padding-left:calc(var(--space-md) + env(safe-area-inset-left,0px));padding-right:calc(var(--space-md) + env(safe-area-inset-right,0px));overflow:visible}.group-settings-page .page-scroll>.container:before{content:"";position:absolute;top:0;left:calc(50% - 50vw - env(safe-area-inset-left,0px));right:calc(50% - 50vw - env(safe-area-inset-right,0px));height:clamp(96px,calc(18vh + var(--safe-area-inset-top)),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:0}.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__admin-toggle{padding-inline:var(--space-sm)}.group-settings-page .page-tabs{margin-bottom:var(--space-md);background:transparent}.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:var(--color-text-inverted)}.category-picker__pill-label--selected:hover,.category-picker__pill-label--selected:focus,.category-picker__pill-label--selected:focus-visible,.category-picker__pill-label--selected:active,.category-picker__pill-label[aria-pressed=true]:hover,.category-picker__pill-label[aria-pressed=true]:focus,.category-picker__pill-label[aria-pressed=true]:focus-visible,.category-picker__pill-label[aria-pressed=true]:active{color:var(--color-text-inverted)}.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:var(--color-text-inverted)}.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 .btn-icon{width:36px;height:36px;border-radius:var(--radius-md);border:none;background:var(--color-bg-secondary);color:var(--color-text-primary);display:inline-flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);padding:0;line-height:1}.category-picker__defaults-editor .btn-icon-primary{background:var(--color-accent);color:#fff}.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:var(--color-text-inverted)}.category-picker__item--selected:hover,.category-picker__item--selected:focus,.category-picker__item--selected:focus-visible,.category-picker__item--selected:active{background:var(--color-accent);color:var(--color-text-inverted)}.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;scrollbar-width:none}.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__item:focus{outline:none;background:none}.friend-multi-select__item--selected:focus,.friend-multi-select__item--selected:hover{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}.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)}.top-drag-card{--top-drag-card-content-height: 0px;border:1px solid var(--backdrop-border-chrome);background:var(--backdrop-fill-chrome);backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);box-shadow:var(--backdrop-shadow-panel);overflow:hidden;pointer-events:auto}.top-drag-card__handle-zone{display:flex;justify-content:center;align-items:center;padding:var(--space-xs) 0;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.top-drag-card.is-dragging .top-drag-card__handle-zone{cursor:grabbing}.top-drag-card__handle{width:56px;height:4px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-text-muted) 28%,transparent);transition:background-color .2s ease,transform .2s ease}.top-drag-card__handle-zone:hover .top-drag-card__handle{background:color-mix(in srgb,var(--color-text-secondary) 38%,transparent)}.top-drag-card.is-dragging .top-drag-card__handle{transform:scaleX(1.08)}.top-drag-card__content{height:var(--top-drag-card-content-height);opacity:0;overflow:hidden;transition:height .28s cubic-bezier(.22,1,.36,1),opacity .22s ease}.top-drag-card__content.is-open{opacity:1}.top-drag-card:not(.is-dragging) .top-drag-card__content{opacity:1}.top-drag-card.is-dragging .top-drag-card__content{transition:none}.top-drag-card__content-inner{min-height:0}.top-drag-card__measure{position:absolute;top:0;left:0;right:0;visibility:hidden;opacity:0;pointer-events:none;z-index:-1}.top-drag-card__measure-view{width:100%}.landing-page{min-height:100vh;display:flex;flex-direction:column;padding:var(--space-lg);padding-top:calc(var(--space-lg) + var(--safe-area-inset-top));padding-bottom:calc(var(--space-lg) + var(--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))}.landing-inner{width:100%;max-width:var(--max-width-narrow);margin:0 auto}.landing-inner--centered{min-height:100vh;display:flex;flex-direction:column;justify-content:center}.landing-screen{height:100vh;overflow:hidden}.landing-screen .landing-inner{min-height:100%;display:flex;flex-direction:column}.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-panel{min-height:280px;display:flex;flex-direction:column}.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-page{position:relative;--home-top-chrome-height: 0px}.home-top-chrome{position:absolute;inset:0 0 auto;z-index:1050;pointer-events:auto}.home-top-panel{background:var(--backdrop-fill-chrome);margin:-3px -3px 0;padding:3px 3px 0;backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);box-shadow:.5px .5px 25px #0000001a,inset .2px .2px 2.5px .1px #ffffff26;border-bottom-left-radius:var(--radius-xl);border-bottom-right-radius:var(--radius-xl)}.home-top-panel__inner{padding-top:var(--space-md);padding-right:var(--space-md);padding-bottom:calc(var(--space-md) + var(--space-xs));padding-left:var(--space-md)}.home-scroll{padding-top:calc(var(--home-top-chrome-height) + var(--space-md));scroll-padding-top:calc(var(--home-top-chrome-height) + var(--space-md))}.active-groups-container{padding-top:var(--space-sm)}.active-groups-list .group-avatar-stack .avatar{width:34px;height:34px}.home-group-list-empty{display:flex;flex-direction:column;gap:var(--space-sm)}.home-group-list-empty .empty-state{padding-bottom:var(--space-md)}.home-hidden-groups-toggle{align-self:center;padding:0;border:0;background:none;color:var(--color-text-placeholder);font-size:var(--font-size-sm);text-decoration:underline;text-underline-offset:.15em;margin-top:var(--space-lg);margin-bottom:var(--space-md)}.home-group-list__content--hidden{opacity:.76}.home-top-timeline{overflow:visible;padding-bottom:0;position:relative;z-index:30}.home-top-panel .timeline-popup{z-index:60}.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)}.chat-container{display:flex;flex-direction:column;height:100%}.group-messages{flex:1;overflow-y:auto;overflow-x:hidden;overscroll-behavior-x:contain;min-height:0;padding:var(--space-md);display:flex;flex-direction:column-reverse;align-self:center;width:100%;max-width:var(--max-width);-webkit-overflow-scrolling:touch;scrollbar-width:none;position:relative;padding-bottom:calc(var(--chat-input-height, 64px) + var(--space-xs))}.chat-content-top-spacer{height:calc(var(--group-header-height, 134px));flex-shrink:0;overflow-anchor:none}.group-messages>*:last-child{margin-bottom:0!important}.group-messages-wrapper{position:relative;flex:1;display:flex;flex-direction:column;min-height:0;width:100%}.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:calc(var(--chat-input-height, 64px) + var(--space-md));right:var(--space-md);width:44px;height:44px;border-radius:50%;background:var(--backdrop-fill-compact);backdrop-filter:var(--backdrop-filter-compact);-webkit-backdrop-filter:var(--backdrop-filter-compact);border:1px solid var(--backdrop-border-compact);box-shadow:var(--backdrop-shadow-compact);display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:transform .2s,opacity .2s,background-color .2s;color:var(--color-text-primary);z-index:1000;opacity:1;visibility:visible}.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.has-reply{max-width:min(calc(var(--max-width) - var(--space-2xl)),calc(100vw - var(--space-2xl) - (2 * var(--space-md))));min-width:0}.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.vote-item.own,.chat-message.vote-item.other{padding:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;border-radius:0;min-width:232px;max-width:min(320px,85%)}.chat-message.vote-item.vote-item--location{max-width:min(360px,90%)}.chat-message.vote-item.own{margin-right:0}.chat-message.vote-item.other{margin-left:0}.chat-message.own{align-self:flex-end;background:var(--backdrop-fill-accent-solid);backdrop-filter:var(--backdrop-filter-accent);-webkit-backdrop-filter:var(--backdrop-filter-accent);color:#fff;border-bottom-right-radius:var(--radius-sm);margin-left:var(--space-2xl)}.chat-message.other{align-self:flex-start;background-color:var(--color-bg-tertiary);border-bottom-left-radius:var(--radius-sm);margin-right:var(--space-2xl)}.chat-message.group-start,.chat-message.group-middle{margin-bottom:var(--space-xs)}.chat-message.group-end{margin-bottom:var(--space-sm)}.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:color-mix(in srgb,white 80%,transparent)}.chat-message.other .chat-timestamp{color:var(--color-text-muted)}.vote-message__timestamp{color:var(--color-text-muted)!important}.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;word-break:break-word}.chat-message.own .message-reply-header{background:#ffffff26;border-left-color:#fffc}.reply-sender{font-weight:600;color:hsl(var(--user-hue),70%,45%)}@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:absolute;bottom:0;left:0;right:0;z-index:100;background:transparent;display:flex;flex-direction:column;width:100%}.chat-input-bar{display:flex;justify-content:center;padding:var(--space-sm);padding-bottom:calc(var(--space-sm) + var(--safe-area-inset-bottom));background:var(--backdrop-fill-chrome);backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);border-top:1px solid var(--backdrop-border-chrome)}.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;border-radius:20px;border:1px solid var(--color-border);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:45px;height:45px;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:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);cursor:not-allowed;opacity:.7}.quick-actions-container{background:var(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);overflow:hidden;max-height:0;transition:max-height .25s cubic-bezier(.4,0,1,1);box-shadow:var(--backdrop-shadow-panel);display:flex;justify-content:center;width:100%;border-top:1px solid transparent}.quick-actions-container.is-open{max-height:180px;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-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:hsl(var(--user-hue, 200),80%,60%);text-decoration:none;font-weight:700;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:var(--backdrop-fill-panel);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);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:var(--backdrop-scrim-soft-bg);backdrop-filter:var(--backdrop-filter-scrim);-webkit-backdrop-filter:var(--backdrop-filter-scrim)}.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;transform-origin:top left;animation:emojiSlideInLeft .16s cubic-bezier(.21,.61,.35,1)}.context-menu-emoji-picker-popover .EmojiPickerReact{border:none!important}.context-menu-emoji-picker-popover.align-right{transform-origin:top right;animation-name:emojiSlideInRight}@keyframes emojiSlideInLeft{0%{opacity:0;transform:translate(-10px) translateY(6px)}to{opacity:1;transform:translate(0) translateY(0)}}@keyframes emojiSlideInRight{0%{opacity:0;transform:translate(10px) translateY(6px)}to{opacity:1;transform:translate(0) translateY(0)}}.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:actionSlideInLeft .16s cubic-bezier(.21,.61,.35,1)}.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-container.align-right .context-menu-actions-inner{animation-name:actionSlideInRight}@keyframes actionSlideInLeft{0%{opacity:0;transform:translate(-8px) translateY(4px)}to{opacity:1;transform:translate(0) translateY(0)}}@keyframes actionSlideInRight{0%{opacity:0;transform:translate(8px) translateY(4px)}to{opacity:1;transform:translate(0) translateY(0)}}.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:-1px -7px 4px;background:#0000000d;border-radius:10px 10px 0 0;cursor:pointer;transition:background .15s}.chat-message.own:not(.group-start) .message-reply-header{border-top-right-radius:6px}.chat-message:not(.own):not(.group-start) .message-reply-header{border-top-left-radius:6px}.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),100%,45%)}@media(prefers-color-scheme:dark){.message-reply-header .reply-sender{color:hsl(var(--user-hue, 200),70%,65%)}}.message-reply-header .reply-text{display:block;font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;min-width:0;max-width:100%}.chat-message.own .message-reply-header .reply-text{color:#ffffffb3}.message-highlight{animation:messageHighlight 1.5s ease-out;border-radius:var(--message-highlight-radius, inherit)}@keyframes messageHighlight{0%,30%{box-shadow:0 0 0 3px var(--color-accent)}to{box-shadow:0 0 #0000}}.chat-message-swipe{position:relative;display:flex;width:100%;min-width:0;box-sizing:border-box}.chat-message-swipe--own{align-self:flex-end;justify-content:flex-end}.chat-message-swipe--other{align-self:flex-start;justify-content:flex-start}.chat-message-swipe .swipeable-content{background-color:transparent;width:auto}.chat-message-swipe .swipeable-actions{overflow:visible}.chat-message-swipe .swipeable-action-btn{background:transparent!important;color:color-mix(in srgb,var(--color-text-secondary) 85%,transparent)}.chat-message-swipe .swipeable-actions--left .swipeable-action-btn{position:relative;justify-content:flex-end;padding-right:0;overflow:visible}.chat-message-swipe .swipeable-actions--left .swipeable-action-icon{position:absolute;right:var(--space-sm)}.chat-message-swipe.group-start,.chat-message-swipe.group-middle{margin-bottom:var(--space-xs)}.chat-message-swipe.group-end{margin-bottom:var(--space-sm)}.chat-message-swipe.has-reactions{margin-bottom:24px}.chat-message-swipe .chat-message.group-start,.chat-message-swipe .chat-message.group-middle,.chat-message-swipe .chat-message.group-end{margin-bottom:0}.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;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:color-mix(in srgb,var(--color-accent) 15%,transparent);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:color-mix(in srgb,var(--color-accent) 15%,transparent);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-page:before{content:"";position:absolute;top:0;left:0;right:0;height:clamp(120px,calc(var(--group-header-height, 140px) + 56px),320px);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:0;right:0;bottom:0;height:clamp(48px,10vh,96px);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) + var(--safe-area-inset-top));background:var(--backdrop-fill-chrome);backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);border-bottom:1px solid var(--backdrop-border-chrome);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{display:grid;grid-template-rows:1fr;opacity:1;overflow:hidden;padding:var(--space-sm) var(--space-sm) 0 var(--space-sm);border-radius:var(--radius-lg);transition:grid-template-rows .2s cubic-bezier(0,0,.2,1),opacity .2s,margin .2s;margin-bottom:0;animation:fadeIn .2s}.group-page.metadata-collapsed .group-metadata{grid-template-rows:0fr;opacity:0;padding-top:0;padding-bottom:0;margin:0;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-row--location{width:100%}.metadata-row__content--location{display:flex;align-items:center;gap:var(--space-xs);min-width:0;flex:1}.metadata-row__text-ellipsis{flex:0 1 auto;min-width:0;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.metadata-nav-button{background:transparent;color:var(--color-text-muted)}.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);color:var(--color-text-inverted)}.decision-buttons-normal .btn-decline.selected{background:var(--color-danger);border-color:var(--color-danger);color:var(--color-text-inverted)}.btn-decision:not(:disabled):hover{filter:brightness(var(--button-hover-brightness))}.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);color:var(--color-text-inverted)}.decision-buttons-compact .btn-decline.selected{background:var(--color-danger);border-color:var(--color-danger);color:var(--color-text-inverted)}.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:6px;font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.2}.metadata-compact-row svg{color:var(--color-text-muted);flex-shrink:0;width:14px;height:14px}.flash{animation:flashHighlight 1.5s ease}@keyframes flashHighlight{0%{color:var(--color-accent);transform:scale(1.05)}to{color:inherit;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.map-page-container{height:100%;position:relative;display:flex;flex-direction:column}.map-legend{position:absolute;bottom:calc(var(--bottom-nav-total-height) + var(--space-sm));left:var(--space-sm);background:var(--backdrop-fill-panel);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-full);box-shadow:var(--backdrop-shadow-compact);z-index:1000;display:flex;align-items:center;gap:var(--space-md);backdrop-filter:var(--backdrop-filter-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);border:1px solid var(--backdrop-border-panel);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.map-center-btn{position:absolute;bottom:calc(var(--bottom-nav-total-height) + var(--space-md));right:var(--space-md);width:44px;height:44px;background:var(--backdrop-fill-chrome);border:none;border-radius:var(--radius-full);color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;box-shadow:var(--backdrop-shadow-panel);z-index:1000;backdrop-filter:var(--backdrop-filter-chrome);-webkit-backdrop-filter:var(--backdrop-filter-chrome);border:1px solid var(--backdrop-border-chrome)}.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:var(--color-accent)}.status-dot.later{background:var(--color-text-muted)}.status-dot.you{background:var(--color-info)}.map-friend-popup{min-width:220px;font-family:var(--font-sans)}.map-friend-popup .group-emoji__icon--legacy{transform:scale(1.35)}.map-friend-main{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);flex-wrap:nowrap}.map-friend-avatar{flex-shrink:0}.map-friend-avatar.avatar-sm{width:36px;height:36px}.map-friend-details{display:flex;flex-direction:column;gap:var(--space-xs);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:var(--space-xs);font-size:10px;font-weight:700;padding:var(--space-xs) var(--space-sm);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:var(--space-xs);margin-top:var(--space-xxs)}.map-friend-row{display:flex;align-items:center;gap:var(--space-sm);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:var(--space-md) 0;width:100%}.leaflet-popup-content-wrapper{background:linear-gradient(180deg,var(--backdrop-fill-modal-strong),var(--backdrop-fill-modal))!important;color:var(--color-text-primary)!important;border-radius:var(--radius-xl)!important;box-shadow:var(--backdrop-shadow-modal)!important;backdrop-filter:var(--backdrop-filter-panel)!important;-webkit-backdrop-filter:var(--backdrop-filter-panel)!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(--backdrop-fill-modal)!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(--backdrop-fill-compact)!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:1px solid var(--backdrop-border-chrome)!important;background:var(--backdrop-fill-chrome)!important;backdrop-filter:var(--backdrop-filter-chrome)!important;-webkit-backdrop-filter:var(--backdrop-filter-chrome)!important;box-shadow:var(--backdrop-shadow-panel)!important;border-radius:var(--radius-md)!important;overflow:hidden}.leaflet-control-zoom a{background:transparent!important;color:var(--color-text-primary)!important;border:none!important}.leaflet-control-zoom a+a{border-top:1px solid var(--backdrop-border-chrome)!important}.leaflet-control-zoom a:hover{background:color-mix(in srgb,var(--backdrop-fill-panel) 85%,transparent)!important}.leaflet-control-zoom a,.map-center-btn,.stats-map-fullscreen-btn{transition:background-color .18s ease,transform .18s ease,box-shadow .18s ease,color .18s ease}.leaflet-control-zoom a:hover,.map-center-btn:hover,.stats-map-fullscreen-btn:hover{background:color-mix(in srgb,var(--backdrop-fill-panel) 85%,transparent)!important}.leaflet-control-zoom a:active,.map-center-btn:active,.stats-map-fullscreen-btn:active{transform:scale(.94);background:color-mix(in srgb,var(--backdrop-fill-panel) 92%,transparent)!important}.leaflet-control-zoom-in{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) + var(--safe-area-inset-bottom))}.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:var(--backdrop-fill-compact);backdrop-filter:var(--backdrop-filter-compact);-webkit-backdrop-filter:var(--backdrop-filter-compact);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:var(--color-text-primary);z-index:1000;border:1px solid var(--backdrop-border-compact);box-shadow:var(--backdrop-shadow-compact)}.map-legend-compact .map-legend-item{display:flex;align-items:center;gap:var(--space-xs)}.map-legend-compact .status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.map-legend-compact .status-dot.you{background:var(--color-info);border:1px solid var(--backdrop-fill-panel-strong)}.map-legend-compact .status-dot.member{background:var(--color-text-muted);border:1px solid var(--backdrop-fill-panel-strong)}.map-legend-compact .status-dot.centroid{background:#6b7280;border:1px solid var(--backdrop-fill-panel-strong)}.map-legend-compact .status-dot.walk{background:var(--color-accent);border:1px solid white}.network-friends-avatar.avatar{width:48px;height:48px}.network-group-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-md);cursor:pointer;transition:background .15s ease}.network-group-item:active{background:var(--color-bg-secondary)}.network-group-item__color{width:3px;height:36px;border-radius:var(--radius-full);flex-shrink:0}.network-group-item__emoji{flex-shrink:0;font-size:1.5rem;line-height:1;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.network-group-item__icon-image{width:100%;height:100%;display:block;object-fit:contain}.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__meta--invite{min-width:0;flex-wrap:wrap;row-gap:4px}.network-group-item__invite-label{flex-shrink:0}.network-group-item__actor-pill{min-width:0;max-width:100%}.network-group-item__notification-indicator{color:var(--color-text-muted)}.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-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)}.friends-sections{display:flex;flex-direction:column;gap:var(--space-lg)}.friends-section{display:flex;flex-direction:column;gap:var(--space-sm)}.friends-section__title{margin:0;font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary)}.friends-section__list{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-primary)}.friends-section__list .list-item{padding:0}.friends-section__empty{margin:0;padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-primary);color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center}.friends-page__search-clear-btn{color:var(--color-text-primary);font-size:16px;font-weight:700;line-height:1}.context-page{position:relative;--context-top-chrome-height: 0px}.context-top-chrome{position:absolute;inset:0 0 auto;padding-top:calc(var(--page-overlay-top-clearance) + var(--space-sm));padding-left:var(--space-sm);padding-right:var(--space-sm);z-index:1050;pointer-events:none}.context-top-card{width:min(var(--max-width),calc(100vw - 2 * var(--space-sm)));margin:0 auto;border-radius:var(--radius-xl)}.context-top-card__tabs{border-top:none}.context-top-card__tabs .page-tabs{position:static;top:auto;background:transparent;border-bottom:1px solid var(--color-border)}.context-top-card.is-collapsed .context-top-card__tabs .page-tabs{border-bottom-color:transparent}.context-top-card.is-collapsed .context-top-card__tabs .page-tab:not(.page-tab--active){border-bottom:none}.context-top-card.is-collapsed .context-top-card__tabs .page-tab:not(.page-tab--active):after{content:"";position:absolute;bottom:-1px;left:var(--space-lg);right:var(--space-lg);height:1px;background:var(--color-border);border-radius:var(--radius-full)}.context-content{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.context-content .page-flex{position:relative}.context-page .leaflet-top{top:calc(var(--context-top-chrome-height) + var(--space-sm))}.context-page .leaflet-left{left:var(--space-sm)}.context-page .leaflet-control-zoom,.context-page .map-center-btn,.context-page .map-legend{z-index:900}.lobby-view{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:calc(var(--context-top-chrome-height) + var(--space-md));padding-bottom:var(--page-overlay-bottom-clearance);scroll-padding-top:calc(var(--context-top-chrome-height) + var(--space-md));scroll-padding-bottom:var(--page-overlay-bottom-clearance)}.lobby-group{margin-bottom:var(--space-md);border-radius:var(--radius-md);border:1px solid transparent;background:transparent;padding:var(--space-xs);transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease}.lobby-group--highlighted{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.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);width:100%}.lobby-group__name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby-group__emoji{font-size:var(--font-size-xl)}.lobby-category{margin-bottom:var(--space-sm);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;border-radius:var(--radius-sm);padding:var(--space-xxs);transition:background-color .2s ease,box-shadow .2s ease,transform .2s ease}.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{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.changelog-page .changelog-title{font-size:var(--font-size-xl);font-weight:700;margin:0}.changelog-card{padding:var(--space-lg)}.changelog-content{display:flex;flex-direction:column;gap:var(--space-md)}.changelog-heading{margin:0;line-height:1.3}.changelog-heading.level-1{font-size:clamp(22px,4vw,26px)}.changelog-heading.level-2{font-size:clamp(20px,3.5vw,24px)}.changelog-heading.level-3{font-size:clamp(18px,3vw,20px)}.changelog-paragraph{margin:0;color:var(--color-text-secondary);line-height:1.6}.changelog-list{margin:0;padding-left:var(--space-lg);display:flex;flex-direction:column;gap:6px;color:var(--color-text-secondary)}.changelog-list li{line-height:1.5}.changelog-code{position:relative;margin:0;padding:var(--space-md);border-radius:var(--radius-md);background:color-mix(in srgb,var(--color-bg-secondary) 85%,transparent);border:1px solid color-mix(in srgb,var(--color-border) 70%,transparent);overflow:auto;font-family:var(--font-family-mono, "JetBrains Mono", "SFMono-Regular", Consolas, monospace);font-size:13px;line-height:1.5}.changelog-code-lang{position:absolute;top:6px;right:8px;font-size:11px;color:var(--color-text-muted)}.changelog-content code{background:color-mix(in srgb,var(--color-bg-secondary) 80%,transparent);border-radius:var(--radius-sm);padding:2px 4px;font-family:var(--font-family-mono, "JetBrains Mono", "SFMono-Regular", Consolas, monospace)}.stats-page{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-lg)}.stats-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);padding:0 var(--space-xs)}.stats-section-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--space-sm) var(--space-xs)}.stats-section-header .stats-section-label{margin:0}.stats-section-title{display:inline-flex;align-items:center;gap:var(--space-xs)}.stats-group-filter-card{padding:0;position:sticky;top:var(--space-md);z-index:1050;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;border:none;box-shadow:none;overflow:visible}.stats-group-dropdown{--stats-group-dropdown-fill: var(--backdrop-fill-chrome);--stats-group-dropdown-filter: var(--backdrop-filter-chrome);position:relative;width:100%;border-radius:var(--radius-lg)}.stats-group-dropdown-trigger{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--stats-group-dropdown-fill);-webkit-backdrop-filter:var(--stats-group-dropdown-filter);backdrop-filter:var(--stats-group-dropdown-filter);border:1px solid var(--backdrop-border-panel);box-shadow:0 4px 8px #0000000f;font-size:var(--font-size-sm);font-family:var(--font-sans);font-weight:500;color:var(--color-text-primary);cursor:pointer;text-align:left;border-radius:var(--radius-lg);position:relative;z-index:1;min-height:40px}.stats-group-dropdown-trigger:hover{background:var(--stats-group-dropdown-fill)}.stats-group-dropdown-icon{display:flex;align-items:center;flex-shrink:0;color:var(--color-accent)}.stats-group-dropdown-label{flex:1;min-width:0;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;line-height:1.2}.stats-group-dropdown-label-text{min-width:0;overflow:hidden;text-overflow:ellipsis}.stats-group-dropdown-label-separator{flex:0 0 auto;color:var(--color-text-muted)}.stats-group-dropdown-emoji-list{display:inline-flex;align-items:center;gap:6px;vertical-align:middle;flex:0 1 auto;min-width:0;overflow:hidden;padding-block:2px}.stats-group-dropdown-emoji{display:inline-flex;align-items:center;line-height:1}.stats-group-dropdown-group-indicator{--group-dot-color: var(--color-accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--radius-full);border:2px solid var(--group-dot-color);background:transparent}.stats-group-dropdown-group-indicator--md{width:20px;height:20px}.stats-group-dropdown-group-indicator--sm{width:18px;height:18px}.stats-group-dropdown-group-indicator__inner{display:inline-flex;align-items:center;justify-content:center;line-height:1}.stats-group-dropdown-group-indicator__emoji{font-size:.7rem;transform:translate(.2px)}.stats-group-dropdown-group-indicator__icon{color:var(--color-bg-primary);border-radius:2px;display:block}.stats-group-dropdown-chevron{flex-shrink:0;color:var(--color-text-muted);transition:transform .15s}.stats-group-dropdown[data-open] .stats-group-dropdown-chevron{transform:rotate(180deg)}.stats-group-dropdown-menu{--stats-group-dropdown-filter: var(--backdrop-filter-chrome);--stats-group-dropdown-fill: var(--backdrop-fill-chrome);display:flex;flex-direction:column;background:var(--stats-group-dropdown-fill);-webkit-backdrop-filter:var(--stats-group-dropdown-filter);backdrop-filter:var(--stats-group-dropdown-filter);border:1px solid var(--backdrop-border-panel);border-radius:var(--radius-lg);box-shadow:0 10px 18px #0000001f;z-index:1200;overflow:hidden}.stats-group-dropdown-actions{padding:var(--space-xs);border-bottom:1px solid color-mix(in srgb,var(--color-border) 72%,transparent)}.stats-group-dropdown-list{display:flex;flex-direction:column;gap:var(--space-xs);overflow-y:auto;padding:var(--space-xs)}.stats-group-dropdown-item{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-sm);background:none;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:var(--font-sans);color:var(--color-text-primary);cursor:pointer;text-align:left;transition:filter .15s ease}.stats-group-dropdown-item--action{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary)}.stats-group-dropdown-item:hover{filter:brightness(var(--button-hover-brightness))}.stats-group-dropdown-item.active{background:var(--backdrop-fill-accent);-webkit-backdrop-filter:var(--backdrop-filter-accent);backdrop-filter:var(--backdrop-filter-accent)}.stats-group-dropdown-item .stats-group-dropdown-icon{color:var(--color-accent)}.stats-group-dropdown-check{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:5px;border:1px solid var(--backdrop-border-panel);background:color-mix(in srgb,var(--color-bg-secondary) 88%,transparent);color:transparent}.stats-group-dropdown-check--checked{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 18%,var(--color-bg-secondary));color:var(--color-accent)}.stats-hero{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.stats-hero .tooltip-container{display:block}.stats-hero .tooltip-trigger{display:block;width:100%}.stats-hero-card{display:flex;flex-direction:row;align-items:center;gap:var(--space-sm);position:relative;padding:var(--space-md);border-radius:var(--radius-lg);box-shadow:0 2px 8px #00000012,0 1px 2px #0000000d,inset 0 1px #ffffff2e;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%}.stats-hero-card-wrap{position:relative;width:100%}.stats-hero-card--streak{background:color-mix(in srgb,var(--color-warning) 9%,var(--color-bg-secondary))}.stats-hero-ice-tooltip.tooltip-container{position:absolute;top:10px;right:10px;z-index:2;display:inline-flex;width:auto}.stats-hero-ice-tooltip .tooltip-trigger{display:inline-flex;width:auto}.stats-hero-ice-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 7px;border-radius:var(--radius-full);background:color-mix(in srgb,var(--color-info) 12%,transparent);color:color-mix(in srgb,var(--color-info) 78%,white);border:none;font-size:var(--font-size-xs);font-family:inherit;font-weight:700;line-height:1;cursor:pointer}.stats-hero-card--score{background:color-mix(in srgb,var(--color-accent) 9%,var(--color-bg-secondary))}.stats-hero-icon{font-size:var(--font-size-2xl);line-height:1;flex-shrink:0}.stats-hero-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);line-height:1;letter-spacing:var(--letter-spacing-tight)}.stats-hero-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.stats-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-md);text-align:center;gap:var(--space-sm);color:var(--color-text-muted)}.stats-empty svg{width:48px;height:48px;opacity:.4}.stats-loading{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl)}.stats-calendar-card{padding:var(--space-sm) var(--space-md) var(--space-sm);height:240px;display:flex;position:relative;z-index:5;overflow:visible}.stats-month-nav{display:flex;align-items:center;gap:var(--space-xs)}.stats-month-nav button{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;width:28px;height:28px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);line-height:1;transition:color .15s}.stats-month-nav button:hover:not(:disabled){background:transparent;color:var(--color-text-primary)}.stats-month-nav button:disabled{opacity:.35;cursor:default}.stats-month-label{min-width:110px;text-align:center;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.stats-calendar{position:relative;touch-action:pan-y;width:100%;height:100%;min-height:0;display:flex;flex-direction:column}.stats-calendar-month{width:100%;flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.stats-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-xs);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.stats-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(var(--cal-rows, 5),1fr);flex:1 1 auto;min-height:0;gap:2px}.stats-calendar-weekday{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);padding:3px 0;font-weight:900;letter-spacing:.03em}.stats-calendar-day{display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--color-text-secondary);position:relative;border:0;background:transparent;width:100%;padding:0;font:inherit;cursor:pointer}.stats-calendar-day:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px;border-radius:var(--radius-md)}.stats-calendar-day.empty{visibility:hidden}.stats-calendar-day.overflow{color:var(--color-text-muted);opacity:.45}.stats-calendar-active-marker{position:absolute;display:flex;align-items:center;justify-content:center;padding:0;margin:0;border:none;background:transparent;transform:translate(-50%,-50%);z-index:4;cursor:grab;touch-action:none;transition:left .26s cubic-bezier(.22,1,.36,1),top .26s cubic-bezier(.22,1,.36,1),width .26s cubic-bezier(.22,1,.36,1),height .26s cubic-bezier(.22,1,.36,1),filter .22s ease;-webkit-tap-highlight-color:transparent}.stats-calendar-active-marker.is-dragging{cursor:grabbing;transition-duration:.12s;filter:saturate(1.08)}.stats-calendar-active-marker:focus{outline:none}.stats-calendar-active-marker:focus-visible .stats-calendar-active-marker__lens{box-shadow:0 10px 28px #00000029,inset 0 1px #ffffff8c,0 0 0 2px color-mix(in srgb,var(--color-bg-primary) 92%,transparent),0 0 0 4px color-mix(in srgb,var(--color-accent) 68%,transparent)}.stats-calendar-active-marker__lens{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;border-radius:var(--radius-full);border:none;outline:2px solid var(--color-text-muted);outline-offset:-1px;background:transparent;box-shadow:0 8px 22px #00000026,inset 0 1px #ffffff38;overflow:visible}.stats-calendar-active-marker__lens:before{content:none}.stats-calendar-active-marker__lens:after{content:none}.stats-day-popover-layer{position:fixed;inset:0;z-index:4200;pointer-events:none}.stats-day-popover{--stats-popover-pointer-offset: 28px;position:absolute;transform:translate(-50%);width:min(340px,calc(100vw - 24px));max-width:calc(100vw - 24px);display:flex;flex-direction:column;background:var(--backdrop-fill-panel);-webkit-backdrop-filter:var(--backdrop-filter-panel);backdrop-filter:var(--backdrop-filter-panel);border:1px solid var(--backdrop-border-panel);border-radius:var(--radius-lg);box-shadow:var(--backdrop-shadow-panel);padding:var(--space-sm);z-index:1;pointer-events:auto;will-change:left,top,transform;transition:left .26s cubic-bezier(.22,1,.36,1),top .26s cubic-bezier(.22,1,.36,1),transform .26s cubic-bezier(.22,1,.36,1),box-shadow .18s ease;animation:stats-day-popover-enter .18s ease-out}.stats-day-popover.is-dragging{transition-duration:.12s}.stats-day-popover:before{content:"";position:absolute;width:20px;height:11px;left:var(--stats-popover-pointer-offset);top:-11px;transform:translate(-50%);background:var(--backdrop-border-panel);clip-path:polygon(50% 0,0 100%,100% 100%)}.stats-day-popover:after{content:"";position:absolute;width:18px;height:10px;left:var(--stats-popover-pointer-offset);top:-10px;transform:translate(-50%);background:var(--backdrop-fill-panel);clip-path:polygon(50% 0,0 100%,100% 100%)}.stats-day-popover--above{transform:translate(-50%,-100%)}.stats-day-popover--above:before{top:auto;bottom:-11px;transform:translate(-50%) rotate(180deg)}.stats-day-popover--above:after{top:auto;bottom:-10px;transform:translate(-50%) rotate(180deg)}@keyframes stats-day-popover-enter{0%{opacity:0}to{opacity:1}}.stats-day-popover__header{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);font-size:var(--font-size-sm);font-weight:700;color:var(--color-text-primary);padding:0 var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-sm)}.stats-day-popover__close{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;margin:-2px -2px -2px 0;border:none;border-radius:var(--radius-full);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:color .16s ease,background-color .16s ease;flex-shrink:0}.stats-day-popover__close:hover{color:var(--color-text-primary);background:color-mix(in srgb,var(--color-bg-tertiary) 72%,transparent)}.stats-day-popover__close:focus{outline:none}.stats-day-popover__close:focus-visible{color:var(--color-text-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-accent) 62%,transparent)}.stats-day-popover__content{min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:2px}.stats-day-popover__section{display:flex;flex-direction:column;gap:6px}.stats-day-popover__section:not(:last-child){margin-bottom:var(--space-sm);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.stats-day-popover__section-title{font-size:var(--font-size-xxs);font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--color-text-muted);padding:4px var(--space-xs);border-radius:var(--radius-sm)}.stats-day-popover__section-title--ready{background:color-mix(in srgb,var(--color-info) 16%,var(--color-bg-primary));color:var(--color-info)}.stats-day-popover__section-title--matched{background:color-mix(in srgb,var(--color-accent) 32%,var(--color-bg-primary));color:var(--color-accent)}.stats-day-popover__ready-groups{display:flex;flex-direction:column;gap:6px;padding:0 var(--space-xs)}.stats-day-popover__ready-row{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.stats-day-popover__ready-times{display:flex;align-items:center;gap:4px;flex-wrap:wrap;padding-left:var(--space-sm)}.stats-day-popover__ready-time{font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;color:var(--color-text-secondary);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);padding:1px 6px;line-height:1.4}.stats-day-popover__ice-note{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);font-weight:600;color:color-mix(in srgb,var(--color-info) 72%,white);background:color-mix(in srgb,var(--color-info) 10%,white);border-radius:var(--radius-sm);padding:1px 6px;line-height:1.4}.stats-day-popover__match-list{display:flex;flex-direction:column;gap:var(--space-xs);padding:0 var(--space-xs)}.stats-day-popover__match-item{display:grid;grid-template-columns:72px minmax(0,1fr) auto;align-items:center;gap:var(--space-sm);min-height:46px;padding:4px 0;width:100%;border:none;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer}.stats-day-popover__match-item:active{background:var(--color-bg-tertiary)}.stats-day-popover__match-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:var(--radius-sm)}.stats-day-popover__match-time-col{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;min-width:0}.stats-day-popover__match-time{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-variant-numeric:tabular-nums;font-weight:600;line-height:1.1;white-space:nowrap}.stats-day-popover__match-details{min-width:0;width:100%}.stats-day-popover__match-context{margin-top:2px;display:flex;align-items:center;font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:0;width:100%}.stats-day-popover__match-context span{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-day-popover__match-avatars{display:flex;align-items:center;justify-content:flex-end;min-width:0;width:fit-content}.stats-day-popover__list{display:flex;flex-direction:column;gap:4px}.stats-day-popover__row{display:grid;grid-template-columns:48px auto minmax(70px,1fr);align-items:center;gap:var(--space-xs);padding:4px var(--space-xs)}.stats-day-popover__time{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.stats-day-popover__context{font-size:var(--font-size-xxs);color:var(--color-text-muted);text-align:right;display:flex;justify-content:flex-end;align-items:center;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-day-popover__empty{padding:2px var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.stats-calendar-day.today{font-weight:800;color:var(--color-text-primary)}.stats-calendar-day.today .stats-calendar-day-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;outline:2px solid var(--color-accent);outline-offset:-1px;border-radius:var(--radius-full)}.stats-calendar-day.ready{color:var(--color-info)}.stats-calendar-day.iced{color:color-mix(in srgb,var(--color-info) 72%,white)}.stats-calendar-day.matched{color:var(--color-accent);font-weight:700}.stats-calendar-day.ready:before{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--color-info) 16%,var(--color-bg-primary));border-radius:var(--radius-full);z-index:0}.stats-calendar-day.iced:before{content:"";position:absolute;inset:0;background:color-mix(in srgb,var(--color-info) 10%,white);border-radius:var(--radius-full);z-index:0}.stats-calendar-day.ready.ready-connect-left:before,.stats-calendar-day.iced.ready-connect-left:before{left:-2px;border-top-left-radius:0;border-bottom-left-radius:0}.stats-calendar-day.ready.ready-connect-right:before,.stats-calendar-day.iced.ready-connect-right:before{border-top-right-radius:0;border-bottom-right-radius:0}.stats-calendar-day.matched:after{content:"";position:absolute;inset:3px;background:color-mix(in srgb,var(--color-accent) 32%,var(--color-bg-primary));border-radius:var(--radius-full);z-index:1}.stats-calendar-day.matched.match-connect-left:after{left:-2px;border-top-left-radius:0;border-bottom-left-radius:0}.stats-calendar-day.matched.match-connect-right:after{right:0;border-top-right-radius:0;border-bottom-right-radius:0}.stats-calendar-day-text{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;min-width:1ch}.stats-calendar-day-marker{position:absolute;top:50%;left:50%;transform:translate(calc(-100% - 10px),-50%);font-size:10px;line-height:1;flex-shrink:0}.stats-calendar-day-number{line-height:1}.stats-calendar-legend{display:flex;gap:var(--space-sm);justify-content:flex-end;flex-wrap:wrap}.stats-calendar-legend--tooltip{flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:var(--space-xs);min-width:120px}.stats-calendar-legend-tooltip .tooltip-trigger{color:var(--color-text-muted)}.stats-legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xxs);color:var(--color-text-muted);font-weight:500}.stats-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.stats-legend-dot.ready{background:var(--color-info)}.stats-legend-dot.matched{background:var(--color-accent)}.stats-legend-dot.ice{background:color-mix(in srgb,var(--color-info) 48%,white)}@media(prefers-color-scheme:dark){.stats-calendar-day.iced{color:color-mix(in srgb,#9ecbff 82%,white)}.stats-calendar-day.iced:before{background:color-mix(in srgb,#9ecbff 24%,var(--color-bg-primary))}.stats-legend-dot.ice{background:color-mix(in srgb,#9ecbff 74%,white)}}.stats-visual-card{height:240px;display:flex}.stats-visual-card>*{flex:1 1 auto;min-height:0}.stats-facts-card{padding:0;overflow:hidden}.stats-fact-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md)}.stats-fact-row:not(:last-child){border-bottom:1px solid var(--color-border)}.stats-fact-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stats-fact-value{font-size:var(--font-size-md);font-weight:700;color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}.stats-fact-row--clickable{cursor:pointer}.stats-fact-row--clickable:active{background:var(--color-bg-tertiary)}.stats-fact-chevron{font-size:var(--font-size-xl);color:var(--color-text-muted);line-height:1;font-weight:300}.stats-partners{padding:var(--space-md) var(--space-md)}.stats-partners-chart{display:flex;flex-direction:column;gap:var(--space-sm)}.stats-partners-bar-row{display:grid;grid-template-columns:minmax(120px,1fr) auto 2fr;align-items:center;gap:var(--space-sm)}.stats-partners-bar-label{display:flex;align-items:center;gap:var(--space-xs);min-width:0}.stats-partners-rank{width:26px;text-align:center;flex-shrink:0;font-size:var(--font-size-sm)}.stats-partners-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:500}.stats-partners-bar-track{height:22px;border-radius:var(--radius-full);overflow:hidden}.stats-partners-bar-fill{height:100%;min-width:3px;background:linear-gradient(90deg,var(--color-accent),color-mix(in srgb,var(--color-accent) 70%,var(--color-info)));border-radius:var(--radius-full)}.stats-category-bars{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(44px,1fr);align-items:end;gap:var(--space-sm);width:100%;height:100%;min-height:0;overflow-x:auto;padding:var(--space-sm) var(--space-xs) 0}.stats-category-bar-item{display:flex;flex-direction:column;align-items:center;min-width:44px;height:100%;gap:6px}.stats-category-bar-count{font-variant-numeric:tabular-nums}.stats-category-bar-track{width:100%;flex:1 1 auto;min-height:0;display:flex;align-items:flex-end;justify-content:center;border-radius:var(--radius-md);background:var(--color-bg-primary);padding:0 6px}.stats-category-bar-fill{--stats-category-color: var(--color-accent);width:100%;min-height:10px;border-radius:var(--radius-sm) var(--radius-sm) 4px 4px;background:linear-gradient(180deg,color-mix(in srgb,var(--stats-category-color) 75%,white),color-mix(in srgb,var(--stats-category-color) 88%,black 4%))}.stats-category-bar-label{width:100%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-status-density{display:flex;flex-direction:column;min-height:0;height:100%;gap:var(--space-xs);padding:var(--space-sm) var(--space-xs) 0 var(--space-xs)}.stats-status-density__frame{position:relative;flex:1 1 auto;min-height:0;padding:var(--space-xs);outline:none;overflow:visible;touch-action:none}.stats-status-density__frame:focus-visible{box-shadow:0 0 0 2px color-mix(in srgb,var(--color-accent) 24%,transparent)}.stats-status-density__slideover.is-visible{opacity:1;transform:translate(-50%) translateY(0) scale(1)}.stats-status-density__slideover{--stats-density-pointer-offset: 50%;position:fixed;left:50%;bottom:calc(100% + var(--space-xs));z-index:4300;width:min(244px,calc(100vw - 24px));display:flex;flex-direction:column;gap:8px;padding:10px 12px;border:1px solid color-mix(in srgb,var(--backdrop-border-panel) 94%,transparent);border-radius:18px;background:linear-gradient(180deg,color-mix(in srgb,var(--backdrop-fill-panel-strong) 92%,white 4%),color-mix(in srgb,var(--backdrop-fill-panel) 96%,transparent));-webkit-backdrop-filter:var(--backdrop-filter-panel);backdrop-filter:var(--backdrop-filter-panel);box-shadow:var(--backdrop-shadow-panel);opacity:0;transform:translate(-50%) translateY(10px) scale(.96);transition:opacity .14s ease,transform .18s cubic-bezier(.22,1,.36,1);pointer-events:none}.stats-status-density__slideover:after{content:"";position:absolute;left:var(--stats-density-pointer-offset);bottom:-7px;width:14px;height:14px;border-right:1px solid color-mix(in srgb,var(--backdrop-border-panel) 94%,transparent);border-bottom:1px solid color-mix(in srgb,var(--backdrop-border-panel) 94%,transparent);background:color-mix(in srgb,var(--backdrop-fill-panel) 98%,transparent);transform:translate(-50%) rotate(45deg)}.stats-status-density__slideover-time{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.01em;color:var(--color-text-primary);font-variant-numeric:tabular-nums}.stats-status-density__slideover-values{display:flex;flex-direction:column;gap:6px;max-height:132px;overflow-y:auto;scrollbar-width:thin}.stats-status-density__slideover-row{--stats-density-color: var(--color-accent);--stats-density-value: 0%;display:flex;flex-direction:column;gap:5px}.stats-status-density__slideover-row-top{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--space-xs)}.stats-status-density__slideover-meta{min-width:0;display:inline-flex;align-items:center;gap:8px}.stats-status-density__slideover-dot{flex:0 0 auto;width:8px;height:8px;border-radius:999px;background:var(--stats-density-color);box-shadow:0 0 0 3px color-mix(in srgb,var(--stats-density-color) 18%,transparent)}.stats-status-density__slideover-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-xs);color:var(--color-text-primary)}.stats-status-density__slideover-metric{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:color-mix(in srgb,var(--stats-density-color) 72%,var(--color-text-primary));font-variant-numeric:tabular-nums}.stats-status-density__slideover-bar{position:relative;display:block;width:100%;height:7px;overflow:hidden;border-radius:999px;background:color-mix(in srgb,var(--stats-density-color) 12%,var(--color-bg-tertiary))}.stats-status-density__slideover-bar-fill{display:block;width:var(--stats-density-value);height:100%;border-radius:inherit;background:linear-gradient(90deg,color-mix(in srgb,var(--stats-density-color) 84%,white 12%),color-mix(in srgb,var(--stats-density-color) 90%,black 4%))}.stats-status-density__svg{position:relative;z-index:1;width:100%;height:100%;overflow:visible}.stats-status-density__grid{fill:none;stroke:color-mix(in srgb,var(--color-border) 80%,transparent);stroke-width:1}.stats-status-density__area{stroke:none}.stats-status-density__line{--stats-density-color: var(--color-accent);fill:none;stroke:var(--stats-density-color);stroke-width:.65;stroke-opacity:.72;stroke-linecap:round;stroke-linejoin:round}.stats-status-density__cursor{stroke:color-mix(in srgb,var(--color-text-primary) 26%,transparent);stroke-width:.7;stroke-dasharray:1.5 1.8;opacity:0;transition:opacity .12s ease}.stats-status-density__point{--stats-density-color: var(--color-accent);fill:var(--color-bg-primary);stroke:var(--stats-density-color);stroke-width:.75;opacity:0;transition:opacity .12s ease}.stats-status-density__frame.is-scrubbing .stats-status-density__cursor,.stats-status-density__frame.is-scrubbing .stats-status-density__point{opacity:1}.stats-status-density__axis{display:flex;justify-content:space-between;font-size:var(--font-size-xxs);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.stats-partners-match-count{min-width:1.5em;text-align:right}.stats-monthly-bars{height:100%;min-height:0;display:flex;flex-direction:column;padding:var(--space-sm) 0 0 0;margin-inline:calc(var(--space-md) * -1);margin-bottom:calc(var(--space-sm) * -1)}.stats-monthly-scroll{height:auto;flex:1 1 auto;min-height:0;display:flex;gap:var(--space-sm);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;scroll-padding-inline:var(--space-lg);scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-inline:var(--space-lg)}.stats-monthly-bar-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 var(--month-item-width, 46px);min-width:var(--month-item-width, 46px);height:100%;scroll-snap-align:start;scroll-snap-stop:always}.stats-monthly-bar-track{width:100%;flex:1;min-height:0;border-radius:var(--radius-md);position:relative;overflow:hidden;display:flex;align-items:flex-end}.stats-monthly-bar-fill{width:100%;background:linear-gradient(180deg,color-mix(in srgb,var(--color-accent) 75%,var(--color-info)),var(--color-accent));border-radius:var(--radius-md) var(--radius-md) 0 0;transition:height .5s cubic-bezier(.4,0,.2,1)}.stats-monthly-bar-count{font-size:var(--font-size-xs);color:var(--color-text-primary);font-weight:700;line-height:1}.stats-monthly-bar-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:500}.stats-map-card{height:240px;padding:0;overflow:hidden}.stats-map-frame{position:relative;height:100%}.stats-map-view{border-radius:var(--radius-md)}.stats-map-fullscreen-btn{position:absolute;top:10px;right:10px;z-index:800;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--backdrop-border-chrome);border-radius:10px;background:var(--backdrop-fill-chrome);color:var(--color-text-primary);box-shadow:var(--backdrop-shadow-panel);-webkit-backdrop-filter:var(--backdrop-filter-chrome);backdrop-filter:var(--backdrop-filter-chrome);cursor:pointer;padding:0;line-height:1;font:inherit;transition:background-color .18s ease,transform .18s ease,box-shadow .18s ease,color .18s ease}.stats-map-fullscreen-btn svg{display:block}.stats-map-fullscreen-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.leaflet-touch .stats-map-fullscreen-btn{width:36px;height:36px}.stats-map-fullscreen-content{flex:1;min-height:0}.stats-map-fullscreen-view{height:100%;width:100%}.stats-empty-preview{position:relative;display:flex;flex:1 1 auto;align-self:stretch;width:100%;height:100%;min-height:240px;overflow:hidden;border-radius:inherit;isolation:isolate}.stats-empty-preview--map{height:100%}.stats-empty-preview-card{padding:0;overflow:hidden}.stats-empty-preview-card>.stats-empty-preview{min-height:100%}.stats-empty-preview__bleed{position:absolute;inset:0;overflow:hidden;border-radius:inherit}.stats-empty-preview--map .stats-empty-preview__bleed{height:100%}.stats-empty-preview__content{position:relative;z-index:0;width:100%;height:100%;pointer-events:none;filter:blur(5px) saturate(.92);transform:scale(1.015);transform-origin:center}.stats-empty-preview__content>*{width:100%}.stats-empty-preview:not(.stats-empty-preview--map) .stats-empty-preview__content{padding:var(--space-md)}.stats-empty-preview--monthly .stats-monthly-scroll{padding-right:var(--space-sm);scroll-padding-right:var(--space-sm)}.stats-empty-preview__blur{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,color-mix(in srgb,var(--color-bg-secondary) 38%,transparent),color-mix(in srgb,var(--color-bg-secondary) 38%,transparent))}.stats-empty-preview__label{position:absolute;top:50%;left:50%;width:calc(100% - (var(--space-md) * 2));transform:translate(-50%,-50%);z-index:2;display:flex;align-items:center;justify-content:center;margin:0;text-align:center;text-wrap:balance;pointer-events:none;text-shadow:0 0 10px var(--color-bg-primary),0 0 18px var(--color-bg-primary),0 0 24px var(--color-bg-primary),0 2px 24px var(--color-bg-primary)}.stats-empty-preview__label.stats-deep-placeholder,.stats-empty-preview__label.stats-map-placeholder{margin:0}.stats-map-preview{position:relative;height:100%;min-height:240px;background:radial-gradient(circle at 18% 22%,color-mix(in srgb,var(--color-info) 18%,transparent),transparent 34%),radial-gradient(circle at 78% 30%,color-mix(in srgb,var(--color-accent) 18%,transparent),transparent 36%),linear-gradient(180deg,#dfe9db,#edf3e7 48%,#d9e5d4)}.stats-map-preview__terrain{position:absolute;inset:0;background:linear-gradient(115deg,transparent 0 22%,rgba(255,255,255,.5) 22% 26%,transparent 26% 100%),linear-gradient(12deg,transparent 0 38%,rgba(255,255,255,.45) 38% 42%,transparent 42% 100%),radial-gradient(circle at 24% 72%,rgba(255,255,255,.44) 0 12%,transparent 12% 100%)}.stats-map-preview__routes{position:absolute;inset:0;width:100%;height:100%}.stats-map-preview__routes path{fill:none;stroke:#405a5457;stroke-linecap:round;stroke-width:2.4}.stats-map-preview__point{--stats-map-preview-size: 52px;--stats-map-preview-color: var(--color-accent);position:absolute;width:var(--stats-map-preview-size);height:var(--stats-map-preview-size);border-radius:999px;transform:translate(-50%,-50%);background:radial-gradient(circle,color-mix(in srgb,var(--stats-map-preview-color) 62%,transparent) 0%,color-mix(in srgb,var(--stats-map-preview-color) 28%,transparent) 42%,transparent 100%);box-shadow:0 0 0 1px color-mix(in srgb,var(--stats-map-preview-color) 12%,transparent)}.stats-heat-icon{background:transparent;border:none}.stats-heat-dot{--heat-size: 22px;--heat-color: var(--color-accent);display:block;width:var(--heat-size);height:var(--heat-size);border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--heat-color) 78%,transparent) 0%,color-mix(in srgb,var(--heat-color) 48%,transparent) 30%,color-mix(in srgb,var(--heat-color) 18%,transparent) 62%,transparent 100%)}.stats-deep-placeholder{padding:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;max-width:22rem}.stats-map-placeholder{padding:var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;max-width:22rem}@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}.whitespace-nowrap{white-space:nowrap}.opacity-70{opacity:.7}.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}.hidden{display:none!important}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-1{flex:1}.items-center{align-items:center}.align-start{align-items:flex-start}.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%}.w-8{width:32px;min-width:32px}.h-8{height:32px;min-height:32px}.mb-0{margin-bottom:0!important}.mb-xs{margin-bottom:var(--space-xs)!important}.mr-xs{margin-right:var(--space-xs)}.ml-xs{margin-left:var(--space-xs)}.ml-sm{margin-left:var(--space-sm)}.p-lg{padding:var(--space-lg)}.gap-xs{gap:var(--space-xs)}.cursor-pointer{cursor:pointer}.min-w-0{min-width:0}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-picks-list{display:flex;flex-direction:column;gap:var(--space-xs);overflow-x:auto;overflow-y:hidden;padding-bottom:2px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.quick-picks-list::-webkit-scrollbar{display:none}.quick-picks-list__row{display:flex;gap:var(--space-xs);width:max-content}.quick-picks-list__row>*{flex:0 0 auto;white-space:nowrap}
