@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root,:root[data-theme=dark]{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a2e;--bg-card-hover:#22223a;--bg-elevated:#252540;--bg-input:#1e1e30;--text-primary:#f0f0f5;--text-secondary:#9898b0;--text-muted:#6a6a80;--text-inverse:#0a0a0f;--accent:#7c3aed;--accent-hover:#6d28d9;--accent-light:#7c3aed26;--accent-glow:#7c3aed4d;--cyan:#06b6d4;--cyan-light:#06b6d426;--success:#10b981;--success-light:#10b98126;--danger:#ef4444;--danger-light:#ef444426;--warning:#f59e0b;--border:#ffffff0f;--border-light:#ffffff1a;--border-accent:#7c3aed4d;--glass-bg:#1a1a2eb3;--glass-border:#ffffff14;--glass-blur:20px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px var(--accent-glow);--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.75rem;--font-sm:.875rem;--font-base:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:2rem;--font-4xl:2.5rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px;--header-height:64px;--max-content-width:680px}:root[data-theme=light]{--bg-primary:#f4f4f5;--bg-secondary:#e4e4e7;--bg-card:#fff;--bg-card-hover:#fafafa;--bg-elevated:#f8f9fa;--bg-input:#fff;--text-primary:#18181b;--text-secondary:#52525b;--text-muted:#71717a;--text-inverse:#fff;--accent:#7c3aed;--accent-hover:#6d28d9;--accent-light:#7c3aed1a;--accent-glow:#7c3aed33;--cyan:#0891b2;--cyan-light:#0891b21a;--success:#059669;--success-light:#0596691a;--danger:#dc2626;--danger-light:#dc26261a;--warning:#d97706;--border:#0000001a;--border-light:#0000000d;--border-accent:#7c3aed33;--glass-bg:#fffc;--glass-border:#0000000d;--shadow-sm:0 1px 3px #0000000d, 0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000014, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -2px #0000000a;--shadow-glow:0 0 15px var(--accent-glow)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);height:100dvh;line-height:1.6;overflow:hidden}#root{height:100dvh;overflow:hidden}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;outline:none}input,textarea{font-family:var(--font-family);background:var(--bg-input);color:var(--text-primary);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-base);transition:all var(--transition-fast);border:none;border:1px solid var(--border);outline:none}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}input::placeholder,textarea::placeholder{color:var(--text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:600;font-size:var(--font-sm);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;border:none;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent), #9333ea);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-light)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{color:var(--text-secondary);padding:var(--space-2) var(--space-3);background:0 0}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-card)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--font-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--font-base)}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-sm)}.badge{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-xs);align-items:center;font-weight:600;display:inline-flex}.badge-active{background:var(--success-light);color:var(--success)}.badge-expired{color:var(--text-muted);background:#ffffff0d}.badge-accent{background:var(--accent-light);color:var(--accent)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.animate-fade-in{animation:fadeIn var(--transition-slow) forwards}.animate-slide-up{animation:slideUp var(--transition-slow) forwards}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-elevated) 50%, var(--bg-card) 75%);border-radius:var(--radius-md);background-size:200px 100%;animation:1.5s infinite shimmer}.spinner{border:2px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}.spinner-lg{border-width:3px;width:40px;height:40px}.leaflet-container{background:var(--bg-primary);width:100%;height:100%}.leaflet-popup-content-wrapper{background:var(--bg-card)!important;color:var(--text-primary)!important;border-radius:var(--radius-lg)!important;border:1px solid var(--border-light)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip{background:var(--bg-card)!important;border:1px solid var(--border-light)!important}.leaflet-popup-close-button{color:var(--text-secondary)!important}.custom-cluster-icon{background:linear-gradient(135deg, var(--accent), #9333ea);color:#fff;width:40px;height:40px;font-weight:700;font-size:var(--font-sm);font-family:var(--font-family);box-shadow:var(--shadow-glow);border:2px solid #fff3;border-radius:50%;justify-content:center;align-items:center;display:flex}.avatar{flex-shrink:0}.avatar-initials{color:#fff;text-transform:uppercase;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-weight:700;display:flex}.layout{height:100dvh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;flex-direction:column;flex-shrink:0;display:flex}.sidebar-header{padding:var(--space-6);border-bottom:1px solid var(--border)}.logo{align-items:center;gap:var(--space-3);color:var(--text-primary);text-decoration:none;display:flex}.logo-icon{object-fit:contain;width:36px;height:36px}.logo-text{font-size:var(--font-xl);background:linear-gradient(135deg, var(--accent), var(--cyan));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-nav{padding:var(--space-4);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);font-weight:500;font-size:var(--font-sm);text-decoration:none;display:flex}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{background:var(--accent-light);color:var(--accent)}.nav-icon{font-size:var(--font-lg);justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.notification-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;animation:2s ease-in-out infinite badge-pulse;display:flex;position:absolute;top:-6px;right:-10px;box-shadow:0 0 8px #ef444466}@keyframes badge-pulse{0%,to{box-shadow:0 0 8px #ef444466}50%{box-shadow:0 0 14px #ef4444b3}}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border);gap:var(--space-3);flex-direction:column;display:flex}.user-card{align-items:center;gap:var(--space-3);padding:var(--space-2);display:flex}.user-info{flex-direction:column;min-width:0;display:flex}.user-name{font-size:var(--font-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.user-handle{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.btn-logout{width:100%;font-size:var(--font-sm);justify-content:flex-start}.main-content{flex:1;position:relative;overflow:hidden}@media (width<=768px){.sidebar{width:100%;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);border-right:none;border-top:1px solid var(--border);flex-direction:row;position:fixed;bottom:0;left:0;right:0}.sidebar-header,.sidebar-footer{display:none}.sidebar-nav{padding:var(--space-2);flex-direction:row;justify-content:space-around;align-items:center}.nav-item{gap:var(--space-1);padding:var(--space-2);font-size:var(--font-xs);flex-direction:column}.nav-label{font-size:10px}.nav-item-feed{order:1}.nav-item-groups{order:2}.nav-item-map{order:3}.nav-item-alerts{order:4}.nav-item-profile{order:5}.main-content{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}}
