*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333;min-height:100vh}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;font-size:1.2rem;color:#666}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.auth-container h1{margin-bottom:2rem;font-size:2rem}.auth-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;width:100%;max-width:400px;display:flex;flex-direction:column;gap:1rem}.auth-form h2{text-align:center;margin-bottom:.5rem}.auth-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.auth-form input:focus{outline:none;border-color:#4a90d9}.auth-form button[type=submit]{padding:.75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.auth-form button[type=submit]:hover{background:#357abd}.auth-form button[type=submit]:disabled{background:#999;cursor:not-allowed}.auth-form .error{color:#d32f2f;font-size:.9rem}.auth-form .message{color:#2e7d32;font-size:.9rem}.auth-form .toggle{text-align:center;font-size:.9rem;color:#666}.auth-form .toggle button{background:none;border:none;color:#4a90d9;cursor:pointer;font-size:.9rem}.app-layout{min-height:100vh}.app-header{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1.5rem;background:#fff;box-shadow:0 1px 4px #0000001a;position:sticky;top:0;z-index:10}.app-title{font-size:1.2rem;font-weight:700;color:#4a90d9;text-decoration:none}.app-nav{display:flex;gap:1rem}.app-nav a{color:#555;text-decoration:none;padding:.25rem .5rem;border-radius:4px}.app-nav a:hover{background:#f0f0f0;color:#333}.app-user{margin-left:auto;display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:#666}.app-user button{padding:.4rem .8rem;background:#666;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.app-user button:hover{background:#555}.app-main{max-width:640px;margin:1.5rem auto;padding:0 1rem}.feed-container,.feed-list{display:flex;flex-direction:column;gap:1rem}.feed-empty{text-align:center;color:#888;padding:2rem}.load-more{padding:.6rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;color:#4a90d9;font-size:.9rem}.load-more:hover{background:#f9f9f9}.load-more:disabled{color:#999;cursor:not-allowed}.post-composer{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:.5rem}.post-composer textarea{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;resize:vertical;min-height:60px}.post-composer textarea:focus{outline:none;border-color:#4a90d9}.post-composer button[type=submit]{align-self:flex-end;padding:.5rem 1.5rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.post-composer button[type=submit]:hover{background:#357abd}.post-composer button[type=submit]:disabled{background:#999;cursor:not-allowed}.post-card{background:#fff;padding:1rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.post-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.post-card-author{font-weight:600;font-size:.95rem}.post-card-time{font-size:.8rem;color:#999}.post-card-content{margin-bottom:.75rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.post-card-footer{display:flex;flex-direction:column;gap:.5rem}.post-card-actions{display:flex;gap:.75rem;align-items:center}.post-card-replies{color:#4a90d9;text-decoration:none;font-size:.9rem}.post-card-replies:hover{text-decoration:underline}.post-card-delete{background:none;border:none;color:#d32f2f;cursor:pointer;font-size:.85rem;padding:0}.post-card-delete:hover{text-decoration:underline}.reaction-bar{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.reaction-pill{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border:1px solid #ddd;border-radius:12px;background:#f9f9f9;cursor:pointer;font-size:.85rem}.reaction-pill:hover{background:#eef}.reaction-pill.active{border-color:#4a90d9;background:#e8f0fe}.reaction-add-wrapper{position:relative}.reaction-add{width:28px;height:28px;border:1px dashed #ccc;border-radius:50%;background:none;cursor:pointer;font-size:1rem;color:#888;display:flex;align-items:center;justify-content:center}.reaction-add:hover{border-color:#4a90d9;color:#4a90d9}.reaction-picker{position:absolute;bottom:100%;left:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000026;padding:.4rem;display:flex;gap:.2rem;z-index:5}.reaction-picker button{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem;border-radius:4px}.reaction-picker button:hover{background:#f0f0f0}.thread-container{display:flex;flex-direction:column;gap:1rem}.thread-back{color:#4a90d9;text-decoration:none;font-size:.9rem}.thread-back:hover{text-decoration:underline}.thread-replies h3{font-size:1rem;color:#666;margin-bottom:.5rem}.thread-replies{display:flex;flex-direction:column;gap:.75rem;padding-left:1rem;border-left:2px solid #e0e0e0}.friends-container{display:flex;flex-direction:column;gap:1.5rem}.friends-container h2{font-size:1.4rem}.friends-search{display:flex;flex-direction:column;gap:.5rem}.friends-search input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.friends-search input:focus{outline:none;border-color:#4a90d9}.search-results{background:#fff;border:1px solid #ddd;border-radius:4px;overflow:hidden}.friends-section h3{font-size:1.1rem;margin-bottom:.5rem}.friends-empty{color:#888;font-size:.95rem}.friend-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #eee}.friend-item:last-child{border-bottom:none}.friend-item button{padding:.35rem .75rem;background:#4a90d9;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem}.friend-item button:hover{background:#357abd}.friend-actions{display:flex;gap:.5rem}.friend-status{font-size:.85rem;color:#888}.btn-danger{background:#d32f2f!important}.btn-danger:hover{background:#b71c1c!important}.message{color:#2e7d32;font-size:.9rem}.error{color:#d32f2f;font-size:.9rem}
