body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.create-post-container{align-items:center;background:var(--bg-secondary);display:flex;justify-content:center;min-height:80vh;padding:var(--space-4)}.create-post-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:600px;overflow:hidden;width:100%}.create-post-header{background:var(--primary);color:var(--text-inverse);padding:var(--space-8) var(--space-6);text-align:center}.create-post-header h1{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.025em;margin-bottom:var(--space-2)}.create-post-header p{font-size:var(--text-base);font-weight:500;opacity:.9}.create-post-form{padding:var(--space-8) var(--space-6)}.post-textarea{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);min-height:120px;padding:var(--space-4);resize:vertical;transition:all var(--transition-fast);width:100%}.post-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.image-label{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:flex;font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.image-label:hover{background:var(--bg-tertiary);border-color:var(--primary)}.image-label span{font-size:var(--text-lg)}.image-input{display:none}.image-preview{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);margin-top:var(--space-2);padding:var(--space-2)}.image-preview p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.form-actions{display:flex;gap:var(--space-4);justify-content:flex-end;margin-top:var(--space-8)}.cancel-btn{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;font-weight:600;min-height:var(--touch-target);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast)}.cancel-btn:hover{background:var(--bg-secondary);border-color:var(--border-dark);box-shadow:var(--shadow-sm);color:var(--text-primary);transform:translateY(-1px)}.submit-btn{padding:var(--space-3) var(--space-6)}.submit-btn:hover:not(:disabled){box-shadow:var(--shadow-sm)}.submit-btn:active{transform:translateY(0)}@media (max-width:768px){.create-post-container{padding:var(--space-3)}.create-post-card{max-width:100%}.create-post-header{padding:var(--space-6) var(--space-4)}.create-post-header h1{font-size:var(--text-xl)}.create-post-form{padding:var(--space-6) var(--space-4)}.form-actions{flex-direction:column;gap:var(--space-3)}.cancel-btn,.submit-btn{width:100%}}.friends-container{background:var(--bg-secondary);min-height:100vh}.friends-header{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6)}.friends-header p{margin:0}.search-container{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--space-4);padding:var(--space-4);position:relative}.search-input{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);min-height:var(--touch-target);padding:var(--space-3) var(--space-12) var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-input::placeholder{color:var(--text-tertiary);font-weight:500}.clear-search-btn{align-items:center;background:none;border:none;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;display:flex;font-size:var(--text-lg);height:var(--touch-target);justify-content:center;padding:var(--space-1);position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%);transition:all var(--transition-fast);width:var(--touch-target)}.clear-search-btn:hover{background:var(--bg-secondary);color:var(--text-secondary)}.mobile-tabs{gap:var(--space-1);margin-bottom:var(--space-4);padding:var(--space-1)}.mobile-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-tertiary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-weight:600;justify-content:center;min-height:var(--touch-target-large);padding:var(--space-3) var(--space-2);position:relative;transition:all var(--transition-fast)}.mobile-tab:hover{background:var(--bg-secondary);color:var(--primary)}.mobile-tab.active{background:var(--primary);box-shadow:var(--shadow-sm);color:var(--text-inverse)}.tab-icon{display:block;font-size:var(--text-xl);margin-bottom:var(--space-1)}.tab-label{font-weight:600;letter-spacing:.05em;text-transform:uppercase}.tab-count,.tab-label{font-size:var(--text-xs)}.tab-count{align-items:center;background:var(--error);border:2px solid var(--bg-primary);border-radius:var(--radius-full);color:var(--text-inverse);display:flex;font-weight:700;height:20px;justify-content:center;position:absolute;right:var(--space-1);top:var(--space-1);width:20px}.friends-content{flex:1 1;overflow-y:auto}.discover-grid,.friends-grid,.requests-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:1fr}.discover-card,.friend-card,.request-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-fast)}.discover-card:hover,.friend-card:hover,.request-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{align-items:flex-start;display:flex;gap:var(--space-4);margin-bottom:var(--space-6)}.user-avatar{align-items:center;background:var(--primary);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);color:var(--text-inverse);display:flex;flex-shrink:0;font-size:var(--text-xl);font-weight:700;height:56px;justify-content:center;width:56px}.user-info{flex:1 1;min-width:0}.username{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;line-height:1.2;margin:0 0 var(--space-2) 0}.user-bio{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--text-secondary);display:-webkit-box;font-size:var(--text-sm);line-height:var(--leading-relaxed);margin:0;overflow:hidden}.request-date{color:var(--text-tertiary);font-size:var(--text-xs);font-weight:500;margin:0}.card-actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.action-btn{border:1px solid #0000;border-radius:var(--radius-lg);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:600;min-height:var(--touch-target);min-width:120px;padding:var(--space-3) var(--space-4);text-align:center;transition:all var(--transition-fast)}.action-btn.primary{background:var(--primary);border-color:var(--primary);color:var(--text-inverse)}.action-btn.primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.action-btn.success{background:var(--success);border-color:var(--success);color:var(--text-inverse)}.action-btn.success:hover:not(:disabled){background:var(--success-light);border-color:var(--success-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.action-btn.danger{background:var(--error);border-color:var(--error);color:var(--text-inverse)}.action-btn.danger:hover{background:var(--error-light);border-color:var(--error-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.action-btn.disabled{background:var(--gray-300);color:var(--text-tertiary);cursor:not-allowed;transform:none}.action-btn.disabled:hover{box-shadow:none;transform:none}.empty-state{border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-12) var(--space-8)}.empty-icon{display:block;font-size:var(--text-4xl);margin-bottom:var(--space-4);opacity:.7}.empty-state h3{font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-2) 0}.empty-state p{color:var(--text-secondary);font-size:var(--text-base);line-height:var(--leading-relaxed);margin:0 0 var(--space-8) 0}.discover-btn{background:var(--primary);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;font-size:var(--text-base);font-weight:600;min-height:var(--touch-target);padding:var(--space-4) var(--space-8);transition:all var(--transition-fast)}.discover-btn:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.loading-state{align-items:center;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:center;padding:var(--space-12) var(--space-8);text-align:center}.loading-spinner{border:3px solid var(--border-light);height:48px;margin-bottom:var(--space-4);width:48px}.loading-state p{color:var(--text-secondary);font-size:var(--text-base);font-weight:500;margin:0}.error-message{align-items:center;border-radius:var(--radius-lg);display:flex;gap:var(--space-2);margin:var(--space-4);padding:var(--space-4)}.error-message span{font-size:var(--text-lg)}.user-modal{animation:slideUp .3s ease-out;border:1px solid var(--border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow:hidden;width:100%}.modal-header,.user-modal{background:var(--bg-primary)}.modal-header{padding:var(--space-6)}.modal-header h2{font-size:var(--text-xl);margin:0}.close-btn{background:none;border:none;border-radius:var(--radius-full);color:var(--text-tertiary);font-size:var(--text-xl);height:var(--touch-target);padding:var(--space-2);transition:all var(--transition-fast);width:var(--touch-target)}.close-btn:hover{background:var(--bg-secondary)}.modal-content{max-height:calc(90vh - 80px);padding:var(--space-6)}.profile-header{border-bottom:1px solid var(--border-light);padding-bottom:var(--space-8)}.profile-avatar{align-items:center;background:var(--primary);border-radius:var(--radius-full);box-shadow:var(--shadow-md);color:var(--text-inverse);display:flex;font-size:var(--text-2xl);font-weight:700;height:80px;justify-content:center;margin:0 auto var(--space-4);width:80px}.profile-username{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-2) 0}.profile-bio{color:var(--text-secondary);font-size:var(--text-base);line-height:var(--leading-relaxed);margin:0;max-width:100%}.profile-stats{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);display:flex;justify-content:space-around;margin-bottom:var(--space-8);padding:var(--space-6)}.stat-item{text-align:center}.stat-value{color:var(--primary);display:block;font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-1)}.stat-label{color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;letter-spacing:.05em;text-transform:uppercase}.mutual-friends{margin-top:var(--space-8)}.mutual-friends h4{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-4) 0}.friends-list{flex-wrap:wrap}.friend-item{gap:var(--space-2);padding:var(--space-2) var(--space-3)}.friend-item:hover{transform:translateY(-1px)}.friend-avatar{align-items:center;background:var(--primary);border-radius:var(--radius-full);color:var(--text-inverse);display:flex;font-size:var(--text-xs);font-weight:700;height:24px;justify-content:center;width:24px}.friend-name{font-size:var(--text-sm)}.more-friends{background:var(--bg-tertiary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--text-xs);font-weight:500;padding:var(--space-2) var(--space-3)}@media (min-width:768px){.friends-container{max-width:800px;padding:var(--space-4)}.friends-header{padding:var(--space-8) var(--space-8)}.friends-header h1{font-size:var(--text-3xl)}.search-container{padding:var(--space-6) var(--space-8)}.mobile-tabs{padding:var(--space-3) var(--space-8)}.friends-content{padding:var(--space-8)}.discover-grid,.friends-grid,.requests-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.user-modal{max-width:600px}.modal-content,.profile-stats{padding:var(--space-8)}}@media (min-width:1024px){.discover-grid,.friends-grid,.requests-grid{gap:var(--space-8);grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}}@media (hover:none) and (pointer:coarse){.mobile-tab:active{transform:scale(.95)}.action-btn:active,.discover-card:active,.friend-card:active,.request-card:active{transform:scale(.98)}}@media (prefers-contrast:high){.discover-card,.friend-card,.request-card{border:2px solid var(--text-primary)}.action-btn{border:1px solid}}@media (prefers-reduced-motion:reduce){.action-btn,.discover-card,.friend-card,.mobile-tab,.request-card{transition:none}.loading-spinner{animation:none}}.privacy-container{align-items:center;display:flex;justify-content:center;min-height:80vh;padding:2rem}.privacy-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:600px;overflow:hidden;width:100%}.privacy-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);color:#2c3e50;padding:2rem;text-align:center}.privacy-header h1{font-size:2rem;font-weight:900;letter-spacing:2px;margin-bottom:.5rem}.privacy-header p{font-size:1rem;opacity:.9}.privacy-content{padding:2rem}.privacy-option{align-items:center;background:#f8f9fa;border:2px solid #e1e5e9;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.option-info h3{color:#000;font-size:1.2rem;font-weight:700;margin-bottom:.5rem}.option-info p{color:#666;margin:0;max-width:400px}.toggle-container{align-items:center;display:flex;flex-direction:column;gap:.5rem}.toggle-switch{display:inline-block;height:34px;position:relative;width:60px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:34px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.4s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:"";height:26px;left:4px;position:absolute;transition:.4s;width:26px}input:checked+.toggle-slider{background-color:#007bff}input:focus+.toggle-slider{box-shadow:0 0 1px #007bff}input:checked+.toggle-slider:before{transform:translateX(26px)}.toggle-label{color:#333;font-size:.9rem;font-weight:600}.privacy-info{background:#f8f9fa;border:1px solid #e1e5e9;border-radius:8px;padding:1.5rem}.privacy-info h4{color:#000;font-size:1.1rem;font-weight:700;margin-bottom:1rem}.privacy-info ul{list-style:none;margin:0;padding:0}.privacy-info li{border-bottom:1px solid #e1e5e9;color:#666;padding:.5rem 0}.privacy-info li:last-child{border-bottom:none}.privacy-info strong{color:#000}.loading{color:#6c757d;font-style:italic;padding:2rem}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;margin:1rem 2rem 0;padding:1rem}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724;margin:1rem 2rem 0;padding:1rem}@media (max-width:768px){.privacy-container{padding:1rem}.privacy-header h1{font-size:1.5rem}.privacy-content{padding:1.5rem}.privacy-option{flex-direction:column;gap:1rem;text-align:center}.option-info p{max-width:none}}.profile-container{background:var(--bg-secondary);min-height:100vh}.profile-header{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6)}.profile-header h1{font-size:var(--text-2xl)}.profile-form{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6)}.form-group,.profile-form{margin-bottom:var(--space-6)}.about-me-input,.form-input,.pet-preference-select,.spotify-input,.username-input,.vibing-input{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.about-me-input:focus,.form-input:focus,.pet-preference-select:focus,.spotify-input:focus,.username-input:focus,.vibing-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.about-me-input{max-height:200px;min-height:100px;resize:vertical}.current-photo{border:3px solid var(--border-light);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);height:120px;margin-bottom:var(--space-4);object-fit:cover;width:120px}.photo-upload{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-medium);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-6);transition:all var(--transition-fast)}.photo-upload:hover{background:var(--bg-tertiary);border-color:var(--primary)}.photo-upload input[type=file]{display:none}.photo-upload label{align-items:center;background:var(--primary);border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;display:flex;font-weight:600;justify-content:center;min-height:var(--touch-target);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast)}.photo-upload label:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.username-edit-form{align-items:flex-end;display:flex;gap:var(--space-3)}.username-edit-form .username-input{flex:1 1;margin-bottom:0}.username-edit-form button{background:var(--primary);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;font-weight:600;min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.username-edit-form button:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.username-edit-form button:active{transform:translateY(0)}.privacy-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--space-6);padding:var(--space-6)}.privacy-section h2{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-4)}.privacy-toggle{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--space-4) 0}.privacy-toggle:last-child{border-bottom:none}.privacy-toggle label{color:var(--text-primary);font-weight:600;margin-bottom:0}.privacy-toggle input[type=checkbox]{accent-color:var(--primary);height:20px;width:20px}.squad-section{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--space-6);padding:var(--space-6)}.squad-section h2{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-4)}.squad-list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-6)}.squad-member{align-items:center;display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4)}.squad-member:hover{transform:translateX(4px)}.member-name{color:var(--text-primary);font-weight:600}.member-actions{align-items:center;display:flex;gap:var(--space-2)}.move-btn,.remove-btn{border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-xs);font-weight:600;min-height:var(--touch-target);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.move-btn{background:var(--gray-300);border-color:var(--gray-300);color:var(--text-secondary)}.move-btn:hover{background:var(--gray-400);border-color:var(--gray-400);transform:scale(1.05)}.remove-btn{background:var(--error);border-color:var(--error);color:var(--text-inverse)}.remove-btn:hover{background:var(--error-light);border-color:var(--error-light);transform:scale(1.05)}.add-to-squad{border-top:1px solid var(--border-light);padding-top:var(--space-6)}.add-to-squad h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:600;margin-bottom:var(--space-4)}.friends-list{display:flex;flex-direction:column;gap:var(--space-3)}.friend-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.friend-item:hover{background:var(--bg-tertiary);border-color:var(--border-medium);transform:translateX(4px)}.friend-name{color:var(--text-primary);font-weight:600}.add-btn{background:var(--success);border:none;border-radius:var(--radius-md);color:var(--text-inverse);cursor:pointer;font-size:var(--text-xs);font-weight:600;min-height:var(--touch-target);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.add-btn:hover{background:var(--success-light);transform:scale(1.05)}.spotify-preview{border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:var(--space-4);overflow:hidden}.danger-zone{background:var(--bg-primary);border:1px solid var(--border-light);border-left:4px solid var(--error);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6)}.danger-zone h2{color:var(--error);font-size:var(--text-xl);font-weight:700;margin-bottom:var(--space-4)}.delete-account-btn{background:var(--error);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;font-size:var(--text-sm);font-weight:600;min-height:var(--touch-target);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast)}.delete-account-btn:hover{background:var(--error-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.error-message,.success-message{border-radius:var(--radius-lg);font-weight:500;margin-bottom:var(--space-4);padding:var(--space-4)}@media (max-width:768px){.profile-container{padding:var(--space-3)}.profile-header{margin-bottom:var(--space-4);padding:var(--space-4)}.profile-header h1{font-size:var(--text-xl)}.danger-zone,.privacy-section,.profile-form,.squad-section{padding:var(--space-4)}.friend-item,.squad-member{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.member-actions{justify-content:flex-end;width:100%}.username-edit-form{align-items:stretch;flex-direction:column}.username-edit-form .username-input{margin-bottom:var(--space-2)}.username-edit-form button{flex:1 1}}@media (max-width:480px){.profile-header h1{font-size:var(--text-lg)}.current-photo{height:100px;width:100px}.friend-item,.squad-member{padding:var(--space-2)}.add-btn,.move-btn,.remove-btn{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}}.notifications-modal{display:flex;flex-direction:column;height:100%;justify-content:flex-end;left:0;position:fixed;top:0;width:100%;z-index:2000}.notifications-backdrop{backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background-color:#0006;height:100%;left:0;position:absolute;top:0;width:100%}.notifications-panel{animation:slideUp .3s ease-out;background:var(--bg-primary);border-radius:20px 20px 0 0;box-shadow:0 -10px 30px #0003;display:flex;flex-direction:column;max-height:85vh;overflow:hidden;position:relative;transform-origin:bottom}.notifications-content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.notifications-header{align-items:center;background:var(--bg-primary);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:20px;position:relative}.header-content{align-items:center;display:flex;gap:12px}.notifications-header h2{color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0}.unread-count-badge{background:var(--primary);border-radius:12px;color:var(--text-inverse);font-size:.75rem;font-weight:600;min-width:20px;padding:4px 8px;text-align:center}.header-actions{align-items:center;display:flex;gap:10px}.mark-all-read-btn{background:var(--primary);border:none;border-radius:8px;color:var(--text-inverse);cursor:pointer;font-size:.8rem;font-weight:600;padding:8px 12px;transition:all .2s ease}.mark-all-read-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.close-btn{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.25rem;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.05)}.notifications-list{flex:1 1;overflow-y:auto;padding:0}.notification-item{align-items:flex-start;border-bottom:1px solid var(--border-light);cursor:pointer;display:flex;padding:16px 20px;position:relative;transition:all .2s ease}.notification-item:hover{background:var(--bg-secondary)}.notification-item.unread{background:#2563eb0d}.notification-item.unread:hover{background:#2563eb14}.notification-item:active{transform:scale(.98)}.notification-content{display:flex;flex:1 1;flex-direction:column;gap:6px;margin-left:12px}.notification-text{color:var(--text-primary);font-size:.9rem;font-weight:500;line-height:1.4}.notification-time{color:var(--text-tertiary);font-size:.75rem;font-weight:500}.notification-icon{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:50%;display:flex;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;width:40px}.unread-indicator{background:var(--primary);border-radius:50%;box-shadow:0 0 0 2px var(--bg-primary);flex-shrink:0;height:8px;margin-left:12px;width:8px}.empty-state{align-items:center;display:flex;flex-direction:column;gap:16px;padding:60px 20px}.empty-icon{font-size:3rem;opacity:.5}.empty-state h3{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0}.empty-state p{color:var(--text-tertiary);font-size:.9rem;margin:0}.loading{align-items:center;display:flex;flex-direction:column;gap:12px;padding:40px 20px}.loading:before{animation:spin 1s linear infinite;border-top:2px solid var(--border-light);border:2px solid var(--border-light);border-radius:50%;border-top-color:var(--primary);content:"";height:24px;width:24px}.error-message{border-bottom:1px solid #dc262633;font-size:.9rem;padding:16px 20px}.notification-badge{display:inline-block}.notification-count{background:#dc3545;border-radius:50%;box-shadow:0 2px 4px #0003;font-weight:700;min-width:20px;right:-8px;top:-8px}@media (max-width:768px){.notifications-panel{max-height:90vh}.notifications-header{padding:16px 20px}.notification-item{padding:14px 20px}.notification-icon{font-size:1.1rem;height:36px;width:36px}.notification-text{font-size:.85rem}.notification-time{font-size:.7rem}}@media (min-width:769px){.notifications-modal{align-items:center;justify-content:center}.notifications-panel{border-radius:20px;margin:20px;max-height:70vh;max-width:500px;width:90%}}.spaces-container{background:var(--bg-secondary);margin:0 auto;max-width:800px;min-height:100vh;padding:var(--space-4)}.spaces-header{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--space-8);padding:var(--space-6);text-align:center}.spaces-header h1{color:var(--text-primary);font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-2)}.spaces-header p{color:var(--text-secondary);font-size:var(--text-base);font-weight:500;margin-bottom:var(--space-6)}.btn-create-space{background:var(--primary);border:none;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--text-inverse);cursor:pointer;font-size:var(--text-base);font-weight:600;max-width:300px;min-height:var(--touch-target);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast);width:100%}.btn-create-space:hover{background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.spaces-content{display:flex;flex-direction:column;gap:var(--space-6)}.mobile-tabs{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;overflow:hidden}.tab-btn{background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:600;min-height:var(--touch-target);padding:var(--space-4);transition:all var(--transition-fast)}.tab-btn.active{background:var(--primary);color:var(--text-inverse)}.tab-btn:hover:not(.active){background:var(--bg-secondary);color:var(--text-primary)}.search-filters{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.search-input,.vibe-filter{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.search-input:focus,.vibe-filter:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.spaces-list{display:flex;flex-direction:column;gap:var(--space-4)}.space-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4);transition:all var(--transition-fast)}.space-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md);transform:translateY(-2px)}.space-header{display:flex;flex-direction:column;gap:var(--space-4);margin-bottom:var(--space-4)}.space-info h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin-bottom:var(--space-2)}.space-info p{color:var(--text-secondary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-3)}.space-meta{display:flex;flex-wrap:wrap;gap:var(--space-2)}.member-count,.privacy-badge,.vibe-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;letter-spacing:.05em;padding:var(--space-1) var(--space-2);text-transform:uppercase}.vibe-badge{background:var(--primary);color:var(--text-inverse)}.member-count{background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-secondary)}.privacy-badge{background:var(--success);color:var(--text-inverse)}.space-actions{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.btn-delete,.btn-edit,.btn-join,.btn-leave,.btn-open,.btn-requests{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:600;justify-content:center;min-height:var(--touch-target);min-width:var(--touch-target);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.btn-join{background:var(--primary);color:var(--text-inverse)}.btn-join:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-open{background:var(--success);color:var(--text-inverse)}.btn-open:hover{background:var(--success-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-edit{background:var(--warning);color:var(--text-inverse)}.btn-edit:hover{background:var(--warning-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-delete{background:var(--error);color:var(--text-inverse)}.btn-delete:hover{background:var(--error-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-leave{background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-secondary)}.btn-leave:hover{background:var(--bg-tertiary);box-shadow:var(--shadow-sm);color:var(--text-primary);transform:translateY(-1px)}.btn-requests{background:var(--primary);color:var(--text-inverse)}.btn-requests:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.space-btn{border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-xs);font-weight:600;min-height:var(--touch-target);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.space-btn.primary{background:var(--primary);border-color:var(--primary);color:var(--text-inverse)}.space-btn.primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.space-btn.secondary{background:var(--bg-secondary);border-color:var(--border-medium);color:var(--text-primary)}.space-btn.secondary:hover{background:var(--bg-tertiary);border-color:var(--border-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.space-btn.danger{background:var(--error);border-color:var(--error);color:var(--text-inverse)}.space-btn.danger:hover{background:var(--error-light);border-color:var(--error-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.chat-modal{background:var(--bg-primary);bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:2000}.chat-header{align-items:center;background:var(--primary);border-bottom:1px solid var(--border-light);color:var(--text-inverse);display:flex;justify-content:space-between;padding:var(--space-4)}.chat-header h3{font-size:var(--text-lg);font-weight:700;margin:0}.btn-close{align-items:center;background:none;border:none;border-radius:var(--radius-full);color:var(--text-inverse);cursor:pointer;display:flex;font-size:var(--text-xl);justify-content:center;min-height:var(--touch-target);min-width:var(--touch-target);padding:var(--space-2);transition:all var(--transition-fast)}.btn-close:hover{background:#fff3}.messages-container{background:var(--bg-secondary);display:flex;flex:1 1;flex-direction:column;gap:var(--space-3);overflow-y:auto;padding:var(--space-4)}.message{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-3);position:relative}.message-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.message-author{color:var(--text-primary);font-size:var(--text-sm);font-weight:600}.message-time{color:var(--text-tertiary);font-size:var(--text-xs)}.message-content{color:var(--text-primary);font-size:var(--text-sm);line-height:var(--leading-relaxed);margin-bottom:var(--space-2)}.message-reactions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-2)}.reaction-btn{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-full);cursor:pointer;font-size:var(--text-xs);padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.reaction-btn:hover{background:var(--primary);border-color:var(--primary);color:var(--text-inverse)}.add-reaction-btn{background:none;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);cursor:pointer;font-size:var(--text-base);padding:var(--space-1);transition:all var(--transition-fast)}.add-reaction-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.message-form{background:var(--bg-primary);border-top:1px solid var(--border-light);display:flex;flex-shrink:0;gap:var(--space-2);padding:var(--space-4)}.message-input{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);flex:1 1;font-size:var(--text-base);min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.message-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.btn-send{background:var(--primary);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;font-weight:600;min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.btn-send:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-load-more{background:var(--bg-secondary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-secondary);cursor:pointer;font-weight:600;margin-top:var(--space-4);min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.btn-load-more:hover{background:var(--bg-tertiary);border-color:var(--border-dark);color:var(--text-primary)}.btn-create-space-small{background:var(--primary);border:none;border-radius:var(--radius-lg);color:var(--text-inverse);cursor:pointer;font-size:var(--text-sm);font-weight:600;margin-top:var(--space-4);min-height:var(--touch-target);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast)}.btn-create-space-small:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.empty-state{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-secondary);font-style:italic;text-align:center}.empty-state,.loading{padding:var(--space-8)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-4);position:fixed;right:0;top:0;z-index:2000}.modal{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--space-6) var(--space-6) var(--space-4)}.modal-header h2{color:var(--text-primary);font-size:var(--text-lg);font-weight:700}.modal-header button{align-items:center;background:none;border:none;border-radius:var(--radius-full);color:var(--text-tertiary);cursor:pointer;display:flex;font-size:var(--text-xl);justify-content:center;min-height:var(--touch-target);min-width:var(--touch-target);padding:var(--space-2);transition:all var(--transition-fast)}.modal-header button:hover{background:var(--bg-secondary);color:var(--text-primary)}.modal-form{padding:var(--space-4) var(--space-6) var(--space-6)}.form-group{margin-bottom:var(--space-5)}.form-group label{color:var(--text-primary);display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:var(--space-2)}.form-group input,.form-group select,.form-group textarea{background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-group textarea{min-height:100px;resize:vertical}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.modal-actions button{border-radius:var(--radius-lg);cursor:pointer;font-weight:600;min-height:var(--touch-target);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.modal-actions .btn-cancel{background:var(--bg-secondary);border:1px solid var(--border-medium);color:var(--text-secondary)}.modal-actions .btn-cancel:hover{background:var(--bg-tertiary);border-color:var(--border-dark);color:var(--text-primary)}.modal-actions .btn-save{background:var(--primary);border:none;color:var(--text-inverse)}.modal-actions .btn-save:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}@media (max-width:768px){.spaces-container{padding:var(--space-3)}.spaces-header{margin-bottom:var(--space-4);padding:var(--space-4)}.spaces-header h1{font-size:var(--text-xl)}.search-filters,.space-card{padding:var(--space-3)}.space-actions{flex-direction:column}.space-btn{width:100%}.message-form{flex-direction:column;gap:var(--space-3)}.btn-send{align-self:flex-end}.modal{max-height:95vh;max-width:95vw}.modal-header{padding:var(--space-4) var(--space-4) var(--space-3)}.modal-form{padding:var(--space-3) var(--space-4) var(--space-4)}.modal-actions{flex-direction:column;gap:var(--space-2)}.modal-actions button{width:100%}}.requests-list{display:flex;flex-direction:column;gap:var(--space-4)}.request-item{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-4);transition:all var(--transition-fast)}.request-item:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.request-info h4{color:var(--text-primary);font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-2)}.request-message{color:var(--text-secondary);font-size:var(--text-sm);font-style:italic;line-height:var(--leading-relaxed);margin-bottom:var(--space-2)}.request-info small{color:var(--text-tertiary);font-size:var(--text-xs)}.request-actions{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.btn-approve,.btn-deny{border:none;border-radius:var(--radius-md);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:600;min-height:var(--touch-target);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.btn-approve{background:var(--success);color:var(--text-inverse)}.btn-approve:hover{background:var(--success-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-deny{background:var(--error);color:var(--text-inverse)}.btn-deny:hover{background:var(--error-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.modal-content{max-height:60vh;overflow-y:auto;padding:var(--space-4)}.private-badge{background:var(--warning);color:var(--text-inverse)}:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#3b82f6;--success:#059669;--success-light:#10b981;--error:#dc2626;--error-light:#ef4444;--warning:#d97706;--warning-light:#f59e0b;--white:#fff;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--text-primary:#111827;--text-secondary:#4b5563;--text-tertiary:#6b7280;--text-inverse:#fff;--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--border-light:#e5e7eb;--border-medium:#d1d5db;--border-dark:#9ca3af;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-2xl:16px;--radius-full:9999px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,"Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.75;--transition-fast:150ms ease;--transition-normal:250ms ease;--transition-slow:350ms ease;--touch-target:44px;--touch-target-large:56px}@media (prefers-color-scheme:dark){:root{--bg-primary:#111827;--bg-secondary:#1f2937;--bg-tertiary:#374151;--text-primary:#f9fafb;--text-secondary:#d1d5db;--text-tertiary:#9ca3af;--border-light:#374151;--border-medium:#4b5563;--border-dark:#6b7280;--gray-50:#111827;--gray-100:#1f2937;--gray-200:#374151;--gray-300:#4b5563;--gray-400:#6b7280;--gray-500:#9ca3af;--gray-600:#d1d5db;--gray-700:#e5e7eb;--gray-800:#f3f4f6;--gray-900:#f9fafb}}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:#f9fafb;background-color:var(--bg-secondary);color:#111827;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans);line-height:1.5;line-height:var(--leading-normal);min-height:100vh;padding-bottom:env(safe-area-inset-bottom);padding-top:env(safe-area-inset-top)}#root,.App{display:flex;flex-direction:column;min-height:100vh}.App{background-color:#f9fafb;background-color:var(--bg-secondary)}.main-nav{align-items:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:#fff;background-color:var(--bg-primary);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;min-height:44px;min-height:var(--touch-target);padding:12px 16px;padding:var(--space-3) var(--space-4);position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-brand h1{color:#2563eb;color:var(--primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:700;letter-spacing:-.025em}.nav-links{gap:12px;gap:var(--space-3);list-style:none}.nav-links,.nav-links li a{align-items:center;display:flex}.nav-links li a{background:#f9fafb;background:var(--bg-secondary);border-radius:8px;border-radius:var(--radius-lg);color:#4b5563;color:var(--text-secondary);font-size:1.125rem;font-size:var(--text-lg);font-weight:500;height:44px;height:var(--touch-target);justify-content:center;text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast);width:44px;width:var(--touch-target)}.nav-links li a.active,.nav-links li a:hover{background:#2563eb;background:var(--primary);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#fff;color:var(--text-inverse);transform:translateY(-1px)}.bottom-nav{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:#fff;background-color:var(--bg-primary);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-light);bottom:0;display:none;left:0;padding:8px 0;padding:var(--space-2) 0;padding-bottom:calc(8px + env(safe-area-inset-bottom));padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom));position:fixed;right:0;z-index:1000}.bottom-nav-links{align-items:center;display:flex;justify-content:space-around;list-style:none;margin:0;padding:0}.bottom-nav-link{align-items:center;background:none;border:none;border-radius:6px;border-radius:var(--radius-md);color:#6b7280;color:var(--text-tertiary);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;font-size:.75rem;font-size:var(--text-xs);font-weight:500;justify-content:center;min-height:44px;min-height:var(--touch-target);min-width:44px;min-width:var(--touch-target);padding:8px;padding:var(--space-2);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.bottom-nav-link.active,.bottom-nav-link:hover{background-color:#f9fafb;background-color:var(--bg-secondary);color:#2563eb;color:var(--primary)}.bottom-nav-icon{display:block;font-size:1.25rem;font-size:var(--text-xl);margin-bottom:4px;margin-bottom:var(--space-1)}.bottom-nav-label{font-size:.75rem;font-size:var(--text-xs);font-weight:500;line-height:1;text-align:center}.main-content{background-color:#f9fafb;background-color:var(--bg-secondary);flex:1 1;margin:0 auto;max-width:100%;width:100%}.auth-container,.main-content{padding:16px;padding:var(--space-4)}.auth-container{align-items:center;background:linear-gradient(135deg,#f9fafb,#f3f4f6);background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-tertiary) 100%);display:flex;justify-content:center;min-height:100vh}.auth-card{animation:slideUp .3s ease-out;background:#fff;background:var(--bg-primary);border-radius:16px;border-radius:var(--radius-2xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-width:400px;overflow:hidden;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-header{background:#2563eb;background:var(--primary);color:#fff;color:var(--text-inverse);padding:32px 24px;padding:var(--space-8) var(--space-6);text-align:center}.auth-title{font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;letter-spacing:-.025em;margin-bottom:8px;margin-bottom:var(--space-2)}.auth-tagline{font-size:.875rem;font-size:var(--text-sm);font-weight:500;opacity:.9}.auth-form-container{padding:32px 24px;padding:var(--space-8) var(--space-6)}.form-title{color:#111827;color:var(--text-primary);font-size:1.25rem;font-size:var(--text-xl);font-weight:600;margin-bottom:8px;margin-bottom:var(--space-2);text-align:center}.form-subtitle{color:#4b5563;color:var(--text-secondary);font-size:.875rem;font-size:var(--text-sm);margin-bottom:24px;margin-bottom:var(--space-6);text-align:center}.auth-form{gap:16px;gap:var(--space-4)}.auth-form,.form-group{display:flex;flex-direction:column}.form-input{background:#fff;background:var(--bg-primary);border:1px solid #d1d5db;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--radius-lg);color:#111827;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);min-height:44px;min-height:var(--touch-target);padding:12px 16px;padding:var(--space-3) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast)}.form-input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input::placeholder{color:#6b7280;color:var(--text-tertiary)}.form-input.error{border-color:#dc2626;border-color:var(--error);box-shadow:0 0 0 3px #dc26261a}.submit-btn{background:#2563eb;background:var(--primary);border:none;border-radius:8px;border-radius:var(--radius-lg);color:#fff;color:var(--text-inverse);cursor:pointer;font-size:1rem;font-size:var(--text-base);font-weight:600;min-height:44px;min-height:var(--touch-target);padding:12px 16px;padding:var(--space-3) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.submit-btn:hover:not(:disabled){background:#1d4ed8;background:var(--primary-dark);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.field-error{color:#dc2626;color:var(--error);font-size:.875rem;font-size:var(--text-sm);font-weight:500;margin-top:4px;margin-top:var(--space-1)}.error-message,.success-message{margin-bottom:16px;margin-bottom:var(--space-4)}.auth-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-light);margin-top:24px;margin-top:var(--space-6);padding-top:24px;padding-top:var(--space-6);text-align:center}.auth-links{flex-wrap:wrap;gap:12px;gap:var(--space-3);justify-content:center}.auth-divider,.auth-links{align-items:center;display:flex}.auth-divider{color:#6b7280;color:var(--text-tertiary);font-size:1.125rem;font-size:var(--text-lg);font-weight:500;line-height:1;margin:0 12px;margin:0 var(--space-3)}.auth-link{color:#2563eb;color:var(--primary);font-size:.875rem;font-size:var(--text-sm);font-weight:500;text-decoration:none;transition:color .15s ease;transition:color var(--transition-fast)}.auth-link:hover{color:#1d4ed8;color:var(--primary-dark);text-decoration:underline}.forgot-password{color:#dc2626!important;color:var(--error)!important;font-weight:600}.forgot-password:hover{color:#ef4444!important;color:var(--error-light)!important}.password-input-container{align-items:center;display:flex;position:relative}.password-toggle{background:none;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-tertiary);cursor:pointer;font-size:1.125rem;font-size:var(--text-lg);padding:4px;padding:var(--space-1);position:absolute;right:12px;right:var(--space-3);transition:all .15s ease;transition:all var(--transition-fast)}.password-toggle:hover{background:#f9fafb;background:var(--bg-secondary)}.checkbox-label,.password-toggle:hover{color:#4b5563;color:var(--text-secondary)}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:.875rem;font-size:var(--text-sm);gap:8px;gap:var(--space-2);margin-bottom:8px;margin-bottom:var(--space-2)}.checkbox-input{accent-color:#2563eb;accent-color:var(--primary);cursor:pointer;height:16px;width:16px}.checkbox-text{font-weight:500;-webkit-user-select:none;user-select:none}.password-requirements{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:6px;border-radius:var(--radius-md);margin-top:12px;margin-top:var(--space-3);padding:12px;padding:var(--space-3)}.password-requirements small{color:#4b5563;color:var(--text-secondary);display:block;font-size:.875rem;font-size:var(--text-sm);font-weight:600;margin-bottom:8px;margin-bottom:var(--space-2)}.password-requirements ul{list-style:none;margin:0;padding:0}.password-requirements li{color:#6b7280;color:var(--text-tertiary);font-size:.75rem;font-size:var(--text-xs);margin-bottom:4px;margin-bottom:var(--space-1);padding-left:20px;padding-left:var(--space-5);position:relative}.password-requirements li:before{background:#d1d5db;background:var(--border-medium);border-radius:50%;content:"";height:12px;left:0;position:absolute;top:2px;width:12px}.password-requirements li.met:before{align-items:center;background:#059669;background:var(--success);color:#fff;color:var(--text-inverse);content:"✓";display:flex;font-size:8px;font-weight:700;justify-content:center}.loading,.password-requirements li.met{color:#4b5563;color:var(--text-secondary)}.loading{font-weight:500;padding:16px;padding:var(--space-4);text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;border:2px solid var(--border-light);border-top-color:var(--primary);display:inline-block;height:20px;margin-right:8px;margin-right:var(--space-2);width:20px}@keyframes spin{to{transform:rotate(1turn)}}.home-content{margin:0 auto;max-width:800px;padding:16px 0;padding:var(--space-4) 0}.home-content h2{color:#111827;color:var(--text-primary);font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;margin-bottom:16px;margin-bottom:var(--space-4);text-align:center}.home-content p{color:#4b5563;color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);line-height:1.75;line-height:var(--leading-relaxed);margin-bottom:24px;margin-bottom:var(--space-6);text-align:center}.posts-feed{display:flex;flex-direction:column;gap:24px;gap:var(--space-6)}.post-card{background:#fff;background:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-xl);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px;padding:var(--space-6);transition:all .15s ease;transition:all var(--transition-fast)}.post-card:hover{border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.post-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:16px;margin-bottom:var(--space-4);padding-bottom:16px;padding-bottom:var(--space-4)}.post-author{color:#111827;color:var(--text-primary);font-size:1rem;font-size:var(--text-base);font-weight:600}.post-date{color:#6b7280;color:var(--text-tertiary);font-size:.875rem;font-size:var(--text-sm);font-weight:500}.post-content,.post-text{margin-bottom:16px;margin-bottom:var(--space-4)}.post-text{color:#111827;color:var(--text-primary);font-size:1rem;font-size:var(--text-base);line-height:1.75;line-height:var(--leading-relaxed)}.post-image{border-radius:8px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:16px;margin-bottom:var(--space-4);max-height:400px;object-fit:cover;width:100%}.post-reactions{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-light);gap:12px;gap:var(--space-3);padding-top:16px;padding-top:var(--space-4)}.post-reactions,.vibes-button{align-items:center;display:flex}.vibes-button{background:#fff;background:var(--bg-primary);border:1px solid #d1d5db;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--radius-lg);cursor:pointer;font-size:1.125rem;font-size:var(--text-lg);justify-content:center;min-height:44px;min-height:var(--touch-target);min-width:44px;min-width:var(--touch-target);padding:8px 12px;padding:var(--space-2) var(--space-3);transition:all .15s ease;transition:all var(--transition-fast)}.vibes-button:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.vibes-button:active{transform:translateY(0)}.quick-reaction-buttons{align-items:center;display:flex;gap:8px;gap:var(--space-2)}.quick-reaction-btn{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #d1d5db;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-size:1.125rem;font-size:var(--text-lg);height:44px;height:var(--touch-target);justify-content:center;transition:all .15s ease;transition:all var(--transition-fast);width:44px;width:var(--touch-target)}.quick-reaction-btn:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:scale(1.05)}.quick-reaction-btn:active{transform:scale(.95)}.more-emojis-btn{align-items:center;background:#fff;background:var(--bg-primary);border:1px solid #d1d5db;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--radius-lg);color:#4b5563;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.125rem;font-size:var(--text-lg);height:44px;height:var(--touch-target);justify-content:center;transition:all .15s ease;transition:all var(--transition-fast);width:44px;width:var(--touch-target)}.more-emojis-btn:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#2563eb;border-color:var(--primary);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#111827;color:var(--text-primary);transform:scale(1.05)}.more-emojis-btn:active{transform:scale(.95)}.vibe-bubble{align-items:center;background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#4b5563;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm);gap:4px;gap:var(--space-1);padding:4px 8px;padding:var(--space-1) var(--space-2);transition:all .15s ease;transition:all var(--transition-fast)}.vibe-bubble:hover{background:#f3f4f6;background:var(--bg-tertiary);border-color:#d1d5db;border-color:var(--border-medium);transform:scale(1.05)}.comments-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-light);margin-top:24px;margin-top:var(--space-6);padding-top:24px;padding-top:var(--space-6)}.comments-list{display:flex;flex-direction:column;gap:16px;gap:var(--space-4);margin-bottom:24px;margin-bottom:var(--space-6)}.comment-card{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-lg);padding:16px;padding:var(--space-4);transition:all .15s ease;transition:all var(--transition-fast)}.comment-card:hover{background:#f3f4f6;background:var(--bg-tertiary);border-color:#d1d5db;border-color:var(--border-medium)}.comment-author{font-weight:600;margin-bottom:8px;margin-bottom:var(--space-2)}.comment-author,.comment-text{color:#111827;color:var(--text-primary);font-size:.875rem;font-size:var(--text-sm)}.comment-text{line-height:1.75;line-height:var(--leading-relaxed)}.add-comment-form{align-items:flex-end;display:flex;gap:12px;gap:var(--space-3)}.comment-input{background:#fff;background:var(--bg-primary);border:1px solid #d1d5db;border:1px solid var(--border-medium);border-radius:8px;border-radius:var(--radius-lg);color:#111827;color:var(--text-primary);flex:1 1;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans);font-size:.875rem;font-size:var(--text-sm);max-height:100px;min-height:44px;min-height:var(--touch-target);padding:12px 16px;padding:var(--space-3) var(--space-4);resize:vertical;transition:all .15s ease;transition:all var(--transition-fast)}.comment-input:focus{border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.add-comment-btn{background:#2563eb;background:var(--primary);border:none;border-radius:8px;border-radius:var(--radius-lg);color:#fff;color:var(--text-inverse);cursor:pointer;font-size:.875rem;font-size:var(--text-sm);font-weight:600;min-height:44px;min-height:var(--touch-target);padding:12px 16px;padding:var(--space-3) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast);white-space:nowrap}.add-comment-btn:hover{background:#1d4ed8;background:var(--primary-dark);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.add-comment-btn:active{transform:translateY(0)}.emoji-picker-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1999}.emoji-picker-container{background-color:#fff;background-color:var(--bg-primary);border-radius:12px;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);left:50%;max-height:80vh;max-width:90vw;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);z-index:2000}.emoji-picker-close,.emoji-picker-container{border:1px solid #e5e7eb;border:1px solid var(--border-light)}.emoji-picker-close{align-items:center;background:#f9fafb;background:var(--bg-secondary);border-radius:50%;color:#4b5563;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;font-size:var(--text-base);height:32px;justify-content:center;position:absolute;right:8px;right:var(--space-2);top:8px;top:var(--space-2);transition:all .15s ease;transition:all var(--transition-fast);width:32px;z-index:10}.emoji-picker-close:hover{background:#f3f4f6;background:var(--bg-tertiary);color:#111827;color:var(--text-primary)}.friends-container{margin:0 auto;max-width:800px;padding:16px;padding:var(--space-4)}.friends-header{margin-bottom:32px;margin-bottom:var(--space-8);text-align:center}.friends-header h1{color:#111827;color:var(--text-primary);font-size:1.875rem;font-size:var(--text-3xl);font-weight:700;margin-bottom:8px;margin-bottom:var(--space-2)}.friends-header p{color:#4b5563;color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);font-weight:500}.profile-container{margin:0 auto;max-width:800px;padding:16px;padding:var(--space-4)}.profile-header{margin-bottom:32px;margin-bottom:var(--space-8);text-align:center}.profile-header h1{color:#111827;color:var(--text-primary);font-size:1.875rem;font-size:var(--text-3xl);font-weight:700;margin-bottom:8px;margin-bottom:var(--space-2)}.profile-header p{color:#4b5563;color:var(--text-secondary);font-size:1rem;font-size:var(--text-base);font-weight:500}.btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans);font-size:.875rem;font-size:var(--text-sm);font-weight:600;justify-content:center;min-height:44px;min-height:var(--touch-target);min-width:44px;min-width:var(--touch-target);padding:8px 16px;padding:var(--space-2) var(--space-4);text-decoration:none;transition:all .15s ease;transition:all var(--transition-fast)}.btn-primary{background:#2563eb;background:var(--primary);border-color:#2563eb;border-color:var(--primary);color:#fff;color:var(--text-inverse)}.btn-primary:hover{background:#1d4ed8;background:var(--primary-dark);border-color:#1d4ed8;border-color:var(--primary-dark);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary{background:#fff;background:var(--bg-primary);border-color:#d1d5db;border-color:var(--border-medium);color:#111827;color:var(--text-primary)}.btn-secondary:hover{background:#f9fafb;background:var(--bg-secondary);border-color:#9ca3af;border-color:var(--border-dark);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-success{background:#059669;background:var(--success);border-color:#059669;border-color:var(--success);color:#fff;color:var(--text-inverse)}.btn-success:hover{background:#10b981;background:var(--success-light);border-color:#10b981;border-color:var(--success-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-danger{background:#dc2626;background:var(--error);border-color:#dc2626;border-color:var(--error);color:#fff;color:var(--text-inverse)}.btn-danger:hover{background:#ef4444;background:var(--error-light);border-color:#ef4444;border-color:var(--error-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.card{background:#fff;background:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-xl);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);margin-bottom:16px;margin-bottom:var(--space-4);padding:24px;padding:var(--space-6);transition:all .15s ease;transition:all var(--transition-fast)}.card:hover{border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-2px)}.user-greeting{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#4b5563;color:var(--text-secondary);font-size:.875rem;font-size:var(--text-sm);font-weight:600;padding:8px 16px;padding:var(--space-2) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast)}.user-greeting:hover{background:#f3f4f6;background:var(--bg-tertiary);border-color:#d1d5db;border-color:var(--border-medium)}.logout-btn{background:#dc2626;background:var(--error);border:none;border-radius:8px;border-radius:var(--radius-lg);color:#fff;color:var(--text-inverse);cursor:pointer;font-size:.875rem;font-size:var(--text-sm);font-weight:600;padding:8px 16px;padding:var(--space-2) var(--space-4);transition:all .15s ease;transition:all var(--transition-fast)}.logout-btn:hover{background:#ef4444;background:var(--error-light);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.logout-btn:active{transform:translateY(0)}.notification-badge{position:relative}.notification-btn{align-items:center;background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-lg);color:#4b5563;color:var(--text-secondary);display:flex;font-weight:500;height:44px;height:var(--touch-target);justify-content:center;overflow:hidden;position:relative;transition:all .15s ease;transition:all var(--transition-fast);width:44px;width:var(--touch-target)}.notification-btn:hover{background:#f3f4f6;background:var(--bg-tertiary);border-color:#d1d5db;border-color:var(--border-medium);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#111827;color:var(--text-primary);transform:translateY(-1px)}.notification-count{font-size:.75rem;font-size:var(--text-xs);font-weight:600;height:20px;right:-4px;top:-4px;width:20px}.mobile-notification-badge,.notification-count{align-items:center;background:#dc2626;background:var(--error);border:2px solid #fff;border:2px solid var(--bg-primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;color:var(--text-inverse);display:flex;justify-content:center;position:absolute}.mobile-notification-badge{box-shadow:0 2px 4px #0003;font-size:.7rem;font-weight:700;height:18px;min-width:18px;right:-2px;top:-2px}.notification-nav-btn{position:relative}.notification-nav-btn.active{background:#2563eb;background:var(--primary);color:#fff;color:var(--text-inverse)}.profile-content{padding:0}.profile-section{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-light);margin-bottom:24px;margin-bottom:var(--space-6);padding-bottom:24px;padding-bottom:var(--space-6)}.profile-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.profile-section h4{color:#111827;color:var(--text-primary);font-size:1.125rem;font-size:var(--text-lg);font-weight:700;margin:0 0 12px;margin:0 0 var(--space-3) 0}.profile-section p{color:#4b5563;color:var(--text-secondary);line-height:1.75;line-height:var(--leading-relaxed);margin:0}.badges-list{display:flex;flex-wrap:wrap;gap:12px;gap:var(--space-3)}.badge-emoji{display:inline-block;transition:all .15s ease;transition:all var(--transition-fast)}.badge-emoji:hover{transform:scale(1.1)}.squad-members{display:flex;flex-wrap:wrap;gap:8px;gap:var(--space-2)}.squad-member{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-lg);color:#111827;color:var(--text-primary);font-size:.875rem;font-size:var(--text-sm);font-weight:600;padding:8px 12px;padding:var(--space-2) var(--space-3);transition:all .15s ease;transition:all var(--transition-fast)}.squad-member:hover{background:#f3f4f6;background:var(--bg-tertiary);border-color:#d1d5db;border-color:var(--border-medium);transform:translateY(-1px)}.song-display{padding:16px;padding:var(--space-4)}.request-sent,.song-display{background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-lg)}.request-sent{color:#4b5563;color:var(--text-secondary);display:inline-block;font-size:.875rem;font-size:var(--text-sm);font-weight:600;padding:12px 16px;padding:var(--space-3) var(--space-4)}.avatar-placeholder.large{align-items:center;background:#2563eb;background:var(--primary);color:#fff;color:var(--text-inverse);display:flex;font-size:1.5rem;font-size:var(--text-2xl);font-weight:700;justify-content:center}.avatar-placeholder.large,.profile-avatar img{border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);height:80px;width:80px}.profile-avatar img{object-fit:cover}.error{color:#dc2626;color:var(--error);font-weight:500;padding:16px;padding:var(--space-4);text-align:center}.success-message{background:#0596691a;border:1px solid #05966933;border-radius:6px;border-radius:var(--radius-md);color:#059669;color:var(--success)}.error-message,.success-message{font-size:.875rem;font-size:var(--text-sm);font-weight:500;margin-top:16px;margin-top:var(--space-4);padding:12px;padding:var(--space-3)}.error-message{background:#dc26261a;border:1px solid #dc262633;border-radius:6px;border-radius:var(--radius-md);color:#dc2626;color:var(--error)}@media (max-width:768px){.desktop-nav{display:none}.mobile-nav{display:block}.main-content{padding-bottom:6rem}.bottom-nav{display:block}.auth-card{margin:16px;margin:var(--space-4)}.auth-form-container,.auth-header{padding:24px 16px;padding:var(--space-6) var(--space-4)}.post-card{padding:16px;padding:var(--space-4)}.post-header{align-items:flex-start;flex-direction:column;gap:8px;gap:var(--space-2)}.add-comment-form{align-items:stretch;flex-direction:column}.add-comment-btn{align-self:flex-end}.emoji-picker-container{max-height:85vh;max-width:95vw}.profile-section{margin-bottom:16px;margin-bottom:var(--space-4);padding-bottom:16px;padding-bottom:var(--space-4)}.profile-section h4{font-size:1rem;font-size:var(--text-base)}.squad-members{gap:4px;gap:var(--space-1)}.squad-member{font-size:.75rem;font-size:var(--text-xs);padding:4px 8px;padding:var(--space-1) var(--space-2)}.song-display{padding:12px;padding:var(--space-3)}}@media (min-width:769px){.desktop-nav{display:flex}.mobile-nav{display:none}.home-content{max-width:800px}.post-card{padding:24px;padding:var(--space-6)}.posts-feed{gap:24px;gap:var(--space-6)}}@media (min-width:1200px){.home-content{max-width:1000px}.post-card{padding:32px;padding:var(--space-8)}.posts-feed{gap:32px;gap:var(--space-8)}}:focus{outline:2px solid #2563eb;outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f9fafb;background:var(--bg-secondary)}::-webkit-scrollbar-thumb,::-webkit-scrollbar-track{border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--border-medium);-webkit-transition:background .25s ease;transition:background .25s ease;-webkit-transition:background var(--transition-normal);transition:background var(--transition-normal)}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--border-dark)}html{scroll-behavior:smooth}@media (hover:none) and (pointer:coarse){.btn:active,.more-emojis-btn:active,.nav-links li a:active,.quick-reaction-btn:active,.vibe-bubble:active{transform:scale(.98)}}@media (prefers-contrast:high){:root{--border-light:#000;--bg-secondary:#f0f0f0}.card{border:2px solid #e5e7eb;border:2px solid var(--border-light)}.btn{border:1px solid}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.loading-spinner{animation:none}}.captcha-container{flex-direction:column}.captcha-container,.captcha-question{display:flex;gap:12px;gap:var(--space-3)}.captcha-question{align-items:center;background:#f9fafb;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-lg);padding:12px 16px;padding:var(--space-3) var(--space-4)}.captcha-text{color:#111827;color:var(--text-primary);flex:1 1;font-weight:600}.captcha-refresh,.captcha-text{font-size:1.125rem;font-size:var(--text-lg)}.captcha-refresh{background:none;border:none;border-radius:4px;border-radius:var(--radius-sm);color:#4b5563;color:var(--text-secondary);cursor:pointer;padding:4px;padding:var(--space-1);transition:all .15s ease;transition:all var(--transition-fast)}.captcha-refresh:hover{background:#f3f4f6;background:var(--bg-tertiary);color:#111827;color:var(--text-primary);transform:rotate(180deg)}.captcha-success{align-items:center;color:#059669;color:var(--success);display:flex;font-size:.875rem;font-size:var(--text-sm);font-weight:600;gap:4px;gap:var(--space-1)}.form-input.success{border-color:#059669;border-color:var(--success);box-shadow:0 0 0 3px #0596691a}.safe-area-top{padding-top:env(safe-area-inset-top)}.safe-area-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-area-left{padding-left:env(safe-area-inset-left)}.safe-area-right{padding-right:env(safe-area-inset-right)}
/*# sourceMappingURL=main.bd5f6029.css.map*/