Gemma 3n-Only AI Assistant - 100% Offline Processing
Clarity is a revolutionary cognitive partner that runs entirely on your device using Google's Gemma 3n model. No cloud, no data transmission, no privacy compromises.
- Live Demo: Visit https://clarity-gemma.netlify.app
- Local Setup: git clone https://github.com/LEAF420/clarity-ai && cd web-ui && npm install && npm run dev
- Open Browser: Navigate to http://localhost:3000
- Complete Onboarding: Follow the privacy-first setup flow
- Import Model: Drag-and-drop a Gemma 3n .gguffile OR use "Skip to Demo Mode"
- Start Chatting: Try the animated example prompts or voice input
- Privacy Champion: Only 100% offline AI assistant in the competition
- Universal Access: Works on any device with 4GB+ RAM
- Cognitive Support: Specifically designed for communication challenges
- Verifiable Privacy: Check Network tab - zero outgoing requests
- Features
- How It Works
- Getting Started
- Model Setup
- Usage Guide
- Privacy & Data
- Ollama Local Mode
- Documentation
- FAQ & Troubleshooting
- Credits & Licensing
- Contact & Feedback
- 🔒 100% Offline Processing: All AI inference happens on your device
- 🛡️ No Data Transmission: Your conversations never leave your device
- ✅ Verifiable Privacy: Check browser Network tab - zero outgoing requests
- 🌐 Airplane Mode Compatible: Works completely offline
- Local Model Mode: Import Gemma 3n .gguffiles for maximum privacy
- Ollama Mode: Connect to local Ollama server for high performance
- Demo Mode: Quick testing with OpenRouter API (privacy warning)
- 🎯 Animated Example Prompts: Interactive carousel with curated communication prompts
- 🎤 Voice Input: Speech-to-text with accessibility support
- 📱 Responsive Design: Works on desktop, tablet, and mobile
- 📊 Structured Output: Confidence-scored suggestions with reasoning
- 📚 Conversation History: Search, filter, and export capabilities
- ♿ Accessibility: WCAG compliant with keyboard navigation and screen reader support
- ⚡ Modern SPA: React 18 + TypeScript + Vite
- 🎨 Beautiful UI: ShadCN UI + Tailwind CSS + Framer Motion
- 🔧 Robust Architecture: Zustand state management + React Router
- 🧪 Comprehensive Testing: Model verification and integrity checks
- Onboard → Learn about privacy-first approach and model requirements
- Import/Connect → Choose your preferred mode (local model, Ollama, or demo)
- Chat → Start communicating with confidence-scored suggestions and reasoning
User Input → Privacy Check → Model Selection → Local Processing → Structured Output
- Local Model Mode: Gemma 3n runs entirely in your browser
- Ollama Mode: Local server provides high-performance inference
- Demo Mode: OpenRouter API for quick testing (privacy warning)
- 🌐 Netlify Deployment: https://clarity-gemma.netlify.app
- 📱 PWA Installable: Add to home screen on mobile devices
- 🔒 Privacy Verified: Check Network tab - zero outgoing requests
- RAM: 4GB minimum, 8GB+ recommended
- Storage: 2GB free space for model files
- Browser: Chrome 113+, Edge 113+, Firefox 115+, Safari 16.4+
- OS: Windows 10+, macOS 10.15+, Linux
# Clone repository
git clone https://github.com/LEAF420/clarity-ai.git
cd clarity
# Install dependencies
cd web-ui
npm install
# Start development server
npm run dev
# Open in browser
# http://localhost:3000# Build for production
npm run build
# Preview production build
npm run preview- Download Gemma 3n: Get from Hugging Face or LM Studio
- Import Model: Drag-and-drop .gguffile into the web interface
- Verify: SHA256 checksum verification ensures model integrity
- Start Chatting: Model runs entirely in your browser
- Install Ollama: Download from ollama.com
- Pull Model: ollama pull gemma3n:e4b
- Start Server: ollama serve
- Connect: Use "Ollama Mode" in the web interface
- Configure: Server URL: http://localhost:11434, Model:gemma3n:e4b
- Skip Model Import: Click "Skip to Online Demo" during onboarding
- API Setup: Configure OpenRouter API key in .env(optional)
- Start Chatting: Uses OpenRouter's Gemma 3n API
- ⚠️ Privacy Warning: Data leaves your device in demo mode
# Create .env file in web-ui directory
VITE_OPENROUTER_API_KEY=your_api_key_here
VITE_OPENROUTER_MODEL=google/gemma-3n-e4b-it:free
VITE_OPENROUTER_URL=https://openrouter.ai/api/v1/chat/completions- Text Input: Type your communication challenges or questions
- Voice Input: Click microphone button for speech-to-text
- Example Prompts: Click animated carousel prompts to auto-fill input
- Structured Output: View confidence-scored suggestions with reasoning
- History View: Browse past conversations and suggestions
- Search: Filter conversations by input text
- Export: Download conversation history as JSON
- Clear: Remove all stored conversations
- Network Tab: Check browser dev tools - zero outgoing requests
- Airplane Mode: Test full offline functionality
- Storage Inspection: Verify local data in IndexedDB
- Enter: Send message
- Shift + Enter: New line
- Escape: Clear input
- Tab: Navigate between elements
- Space: Activate buttons
- Screen Reader: Full ARIA support and semantic HTML
- Keyboard Navigation: Complete keyboard accessibility
- High Contrast: WCAG compliant color schemes
- Reduced Motion: Respects user motion preferences
- ✅ 100% Offline: No network requests after model import
- ✅ Local Processing: All AI inference happens on your device
- ✅ No Data Transmission: Conversations never leave your device
- ✅ Verifiable: Check Network tab - zero outgoing requests
- ✅ Local Processing: All inference via local Ollama server
- ✅ No Cloud Dependencies: No external API calls
- ✅ Local Storage: Conversations stored in browser only
- ✅ Privacy Verified: No data leaves your device
- ⚠️ Data Transmission: Conversations sent to OpenRouter servers
- ⚠️ API Logging: Requests may be logged by OpenRouter
- ⚠️ Internet Required: Won't work offline
- ⚠️ Use Only For: Testing and demonstrations
- Model Files: Stored in browser IndexedDB (local model mode)
- Conversations: Stored in browser localStorage/IndexedDB
- Settings: Stored in browser localStorage
- No Cloud Storage: All data remains on your device
- App Reset: Click Clarity logo → Confirm reset
- Browser Clear: Clear site data in browser settings
- Export First: Download conversations before clearing
For detailed privacy information, see Privacy Guide.
- Install Ollama: Download from ollama.com
- Pull Model: ollama pull gemma3n:e4b
- Start Server: ollama serve(keep terminal open)
- Connect: Use "Ollama Mode" in web interface
- Configure: Server URL: http://localhost:11434, Model:gemma3n:e4b
- Faster Inference: Local server processing
- Better Memory Management: Optimized for large models
- GPU Acceleration: Hardware acceleration support
- High Privacy: 100% local processing
- Connection Failed: Ensure ollama serveis running
- Model Not Found: Run ollama pull gemma3n:e4b
- Port Issues: Check firewall allows port 11434
- Memory Issues: Use smaller model (gemma3n:e2b)
For detailed setup instructions, see Ollama Guide.
- 📋 FAQ - Common issues, browser compatibility, troubleshooting
- 🏗️ Architecture - System overview, data flow, extensibility
- 🔒 Privacy - Privacy guarantees, data handling, verification
- ⚙️ Ollama Setup - Local AI inference with Ollama
- 🔧 Troubleshooting - Comprehensive debugging guide
- 📦 Model Acquisition - How to get Gemma 3n models
- 🧪 Testing Guide - Validation and testing procedures
- File Format: Ensure .ggufextension
- File Size: Between 100MB and 15GB
- Browser Storage: Clear browser data if quota exceeded
- Browser Support: Use Chrome/Edge for best compatibility
- Browser Support: Chrome/Edge (best), Safari (limited), Firefox (not supported)
- Permissions: Allow microphone access when prompted
- HTTPS Required: Some browsers require secure connection
- Fallback: Use text input if voice doesn't work
- Server Running: Ensure ollama serveis active
- Port Access: Check firewall allows port 11434
- Model Downloaded: Run ollama pull gemma3n:e4b
- Network: Verify localhost connectivity
- Memory: Close other applications to free RAM
- Model Size: Use smaller model (gemma3n:e2b) for limited resources
- Browser: Update to latest version for WebGPU support
- Storage: Ensure sufficient disk space
- Network Tab: Check browser dev tools for zero outgoing requests
- Airplane Mode: Test full offline functionality
- Storage Inspection: Verify local data in IndexedDB
- Demo Mode Warning: Only use for testing, not sensitive conversations
For detailed troubleshooting, see FAQ and Troubleshooting Guide.
- Privacy Champion: Only 100% offline AI assistant in the competition
- Universal Access: Works on any device with 4GB+ RAM
- Cognitive Support: Specifically designed for communication challenges
- Verifiable Privacy: Check Network tab - zero outgoing requests
- Modern SPA: React 18 + TypeScript + Vite
- Beautiful UI: ShadCN UI + Tailwind CSS + Framer Motion
- Robust Architecture: Zustand state management + React Router
- Comprehensive Testing: Model verification and integrity checks
- Smooth Onboarding: Privacy-first setup with clear explanations
- Multiple Modes: Local model, Ollama, and demo options
- Accessibility: WCAG compliant with keyboard navigation
- Responsive Design: Works on desktop, tablet, and mobile
- Gemma 3n: Google's Gemma 3n E2B-it/E4B-it models
- License: Gemma Use Policy
- Attribution: Google/Gemma for model architecture and training
- Frontend: React 18, TypeScript, Vite
- UI Components: ShadCN UI, Tailwind CSS, Lucide Icons
- Animations: Framer Motion
- State Management: Zustand
- Voice Input: Web Speech API
- Local Storage: IndexedDB, localStorage
- OpenRouter: Demo mode API provider
- Ollama: Local inference server
- Hugging Face: Model distribution platform
- Kaggle Gemma 3n Showcase: Competition Link
- Prize Tracks: Ollama Prize, Edge Prize, Unsloth Prize
- Submission Category: Privacy-First AI Assistant
- Code: MIT License (open source)
- Documentation: Creative Commons
- Models: Gemma Use Policy (Google)
- GitHub Issues: Report bugs and feature requests
- Documentation: Check FAQ and Troubleshooting
- Community: Join discussions and get help
- Demo Video: [Link to demo video]
- Live Demo: Available during competition judging
- Technical Questions: Contact via GitHub issues
We welcome contributions! Please see our contributing guidelines for:
- Code improvements and bug fixes
- Documentation updates
- Feature suggestions
- Accessibility enhancements
- 🌐 Live Demo: https://clarity-gemma.netlify.app
- 📱 PWA Ready: Installable on mobile devices
- 🔒 Privacy Verified: Zero network requests after model import
- Connect Repository: Link GitHub repo to Netlify
- Configure Build: Set build command to npm run build
- Set Environment Variables: Add OpenRouter API key and settings
- Deploy: Automatic deployment with live updates
VITE_OPENROUTER_API_KEY=your_api_key_here
VITE_OPENROUTER_MODEL=google/gemma-3n-e4b-it:free
VITE_OPENROUTER_URL=https://openrouter.ai/api/v1/chat/completions
VITE_DEMO_MODE_ENABLED=true
VITE_APP_URL=https://your-site-name.netlify.appFor detailed deployment instructions, see web-ui/README.md.
Built with ❤️ for the Kaggle Gemma 3n Showcase Competition
Clarity: Empowering communication through privacy-first AI