apps/android/style.md
Scope: all native Android UI in apps/android (Jetpack Compose).
Goal: one coherent visual system across onboarding, settings, and future screens.
The onboarding flow defines the current visual baseline. New screens should match that language unless there is a strong product reason not to.
Baseline traits:
Use these as shared design tokens for new Compose UI.
#FFFFFF, #F7F8FA, #EFF1F5#F6F7FA#E5E7EC#D6DAE2#17181C#4D5563#8A92A2#1D5DD8#ECF3FF#2F8C5A#C8841ARule: do not introduce random per-screen colors when an existing token fits.
Primary type family: Manrope (400/500/600/700).
Recommended scale:
34sp / 40sp, bold24sp / 30sp, semibold16sp / 22sp, semibold15sp / 22sp, medium14sp / 20sp, medium12sp / 16sp, medium11sp / 14sp, mediumUse monospace only for commands, setup codes, endpoint-like values. Hard rule: avoid ultra-thin weights on light backgrounds.
8/10/12/14/20dp.Manual, Advanced, etc.).Step X of N).44dp.contentDescription for icon-only controls.MainViewModel.LaunchedEffect, activity result APIs).app/src/main/java/ai/openclaw/android/ui/OpenClawTheme.ktapp/src/main/java/ai/openclaw/android/ui/OnboardingFlow.ktapp/src/main/java/ai/openclaw/android/ui/RootScreen.ktapp/src/main/java/ai/openclaw/android/ui/SettingsSheet.ktapp/src/main/java/ai/openclaw/android/MainViewModel.ktIf style and implementation diverge, update both in the same change.