.notif-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.notif-bell-btn{color:var(--foreground);opacity:.8;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:relative}.notif-bell-btn:hover{opacity:1;background:#ffffff0d}.notif-badge{color:#fff;border:2px solid var(--background);background:#ef4444;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.65rem;font-weight:800;display:flex;position:absolute;top:2px;right:2px}.notif-dropdown{background:var(--surface);border:1px solid var(--border);z-index:1000;border-radius:12px;flex-direction:column;width:340px;max-height:400px;display:flex;position:absolute;top:calc(100% + 10px);right:-10px;overflow:hidden;box-shadow:0 10px 30px #00000080}.notif-dropdown:before{content:"";background:var(--surface);border-top:1px solid var(--border);border-left:1px solid var(--border);width:12px;height:12px;position:absolute;top:-6px;right:20px;transform:rotate(45deg)}.notif-header{border-bottom:1px solid var(--border);z-index:2;background:var(--surface);padding:12px 16px;position:relative}.notif-header h3{color:var(--primary);margin:0;font-size:1.1rem;font-weight:800}.notif-list{z-index:2;background:var(--surface);flex:1;position:relative;overflow-y:auto}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.notif-empty{text-align:center;opacity:.5;padding:2rem 1rem;font-size:.9rem}.notif-item{border-bottom:1px solid #ffffff0d;gap:12px;padding:12px 16px;transition:background .2s;display:flex}.notif-item:hover{background:#ffffff08}.notif-item.unread{background:#f43f5e0d}.notif-avatar-col{flex-shrink:0}.notif-avatar{object-fit:cover;background:#ffffff1a;border-radius:50%;width:40px;height:40px}.system-icon{background:linear-gradient(135deg,#f43f5e 0%,#e11d48 100%);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.notif-content-col{flex-direction:column;flex:1;justify-content:center;min-width:0;display:flex}.notif-text{color:#1e293b;margin:0 0 4px;font-size:.9rem;font-weight:500;line-height:1.4}.notif-text strong{color:var(--primary);font-weight:700}.notif-time{color:#64748b;font-size:.75rem;font-weight:500}@media (prefers-color-scheme:dark){.notif-text{color:#e2e8f0}.notif-time{color:#94a3b8}}@media (max-width:400px){.notif-dropdown{width:auto;position:fixed;top:60px;left:10px;right:10px}}
.auth-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;background:#000000b8;justify-content:center;align-items:center;padding:1rem;animation:.2s overlayIn;display:flex;position:fixed;inset:0}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.auth-modal{background:var(--glass-bg);-webkit-backdrop-filter:blur(28px)saturate(180%);border:1px solid var(--glass-border);border-radius:var(--radius-lg);width:100%;max-width:460px;max-height:90vh;color:var(--foreground);padding:2rem 2rem 1.5rem;animation:.3s cubic-bezier(.16,1,.3,1) modalSlideUp;position:relative;overflow-y:auto;box-shadow:0 24px 64px #00000080,inset 0 1px #ffffff14}.auth-modal::-webkit-scrollbar{width:4px}.auth-modal::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-close-btn{color:var(--foreground);cursor:pointer;background:#0000000d;border:1px solid #0000001a;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;transition:background .2s,transform .2s;display:flex;position:absolute;top:1rem;right:1rem}.auth-close-btn:hover{background:#0000001a;transform:rotate(90deg)}.auth-header{text-align:center;margin-bottom:1.5rem}.auth-logo-icon{border-radius:var(--radius-md);color:#fff;background:linear-gradient(135deg,#ff3b30 0%,#dc0000 100%);justify-content:center;align-items:center;width:3rem;height:3rem;margin:0 auto .75rem;font-size:1.5rem;font-weight:900;display:flex;box-shadow:0 6px 20px #dc000033}.auth-title{color:var(--foreground);letter-spacing:-.02em;margin:0 0 .3rem;font-size:1.4rem;font-weight:800}.auth-subtitle{color:var(--text-muted);margin:0;font-size:.9rem}.auth-tabs{border-radius:var(--radius-md);background:#ffffff0a;border:1px solid #ffffff14;grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-bottom:1.5rem;padding:.4rem;display:grid}.auth-tab-btn{color:var(--text-muted);text-transform:uppercase;border-radius:var(--radius-sm);cursor:pointer;background:0 0;border:none;padding:.65rem .2rem;font-family:inherit;font-size:.75rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1)}.auth-tab-btn.active{color:#a855f7;background:#8b5cf626;box-shadow:0 4px 12px #0003,inset 0 -2px #a855f7}.auth-tab-btn:not(.active):hover{color:var(--foreground);background:#ffffff0d}.auth-tab-content{animation:.2s tabFadeIn}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.auth-help-text{opacity:.55;margin:0 0 .75rem;font-size:.8rem}.auth-terms-label{color:var(--text-muted);cursor:pointer;align-items:flex-start;gap:.5rem;margin-top:.5rem;font-size:.8rem;display:flex}.auth-terms-label a{color:var(--primary);text-decoration:underline}.auth-empty-state{text-align:center;opacity:.6;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem 0;font-size:.9rem;display:flex}.auth-field-group{margin-bottom:1.25rem}.auth-label{text-transform:uppercase;letter-spacing:.6px;color:#fff9;margin-bottom:.5rem;font-size:.78rem;font-weight:700;display:block}.auth-input{border-radius:var(--radius-sm);color:#fff;box-sizing:border-box;background:#ffffff0d;border:1px solid #ffffff26;width:100%;padding:.85rem 1rem;font-size:.95rem;transition:all .3s cubic-bezier(.16,1,.3,1)}.auth-input:focus{background:#ffffff1a;border-color:#a855f7;outline:none;box-shadow:0 0 0 3px #a855f740}.google-auth-btn{color:#333;border-radius:var(--radius-sm);cursor:pointer;background:#fff;border:1px solid #0000001a;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem;font-size:.85rem;font-weight:600;transition:background .2s;display:flex}.google-auth-btn:hover{background:#f9f9f9}.auth-avatar-grid{grid-template-columns:repeat(6,1fr);gap:.5rem;display:grid}.auth-avatar-option{cursor:pointer;aspect-ratio:1;background:#ffffff0a;border:2px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;padding:.2rem;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.auth-avatar-option:hover{border-color:#f43f5e80;transform:scale(1.08)}.auth-avatar-option.selected{border-color:#f43f5e;transform:scale(1.1);box-shadow:0 0 0 2px #f43f5e66,0 4px 12px #f43f5e40}.auth-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-checkmark{color:#fff;background:#f43f5e;border:1.5px solid #0a031ce6;border-radius:50%;justify-content:center;align-items:center;width:1rem;height:1rem;font-size:.55rem;font-weight:900;display:flex;position:absolute;bottom:-2px;right:-2px}.auth-preview{border-radius:var(--radius-md);background:#f43f5e12;border:1px solid #f43f5e33;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.7rem 1rem;animation:.2s tabFadeIn;display:flex}.auth-preview-avatar{background:#ffffff0d;border:2px solid #f43f5e66;border-radius:50%;width:2.25rem;height:2.25rem}.auth-preview-name{color:#fff;font-size:.95rem;font-weight:700}.auth-error{color:#f87171;border-radius:var(--radius-sm);background:#f871711a;border-left:3px solid #f87171;margin:-.25rem 0 .75rem;padding:.4rem .75rem;font-size:.8rem}.auth-submit-btn{color:#fff;cursor:pointer;border:none;width:100%;margin-top:.25rem;font-size:.95rem;font-weight:700;transition:transform .3s,box-shadow .3s;box-shadow:0 8px 24px #8b5cf659;border-radius:var(--radius-md)!important;background:var(--primary)!important;padding:.85rem!important}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #8b5cf673;background:var(--primary-hover)!important}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-loading-dots span{animation:1s step-start infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.auth-footer-note{text-align:center;opacity:.3;margin:1rem 0 0;font-size:.72rem}
