diff --git a/core/embed/rust/src/ui/layout_delizia/component/footer.rs b/core/embed/rust/src/ui/layout_delizia/component/footer.rs
index 08132dab4c..7ec0bf579c 100644
--- a/core/embed/rust/src/ui/layout_delizia/component/footer.rs
+++ b/core/embed/rust/src/ui/layout_delizia/component/footer.rs
@@ -17,7 +17,9 @@ use super::{super::fonts::FONT_SUB, theme, Button, ButtonMsg};
 /// Component showing a task instruction, e.g. "Swipe up", and an optional
 /// content consisting of one of these:
 ///     - a task description e.g. "Confirm transaction", or
-///     - a page counter e.g. "1 / 3", meaning the first screen of three total.
+///     - a page counter e.g. "1 / 3", meaning the first screen of three total,
+///       or
+///     - a page hint e.g. "Go back" if you are on the last page.
 /// A host of this component is responsible of providing the exact area
 /// considering also the spacing. The height must be 18px (only instruction) or
 /// 37px (instruction and description/position).
diff --git a/core/embed/rust/src/ui/layout_eckhart/component/hint.rs b/core/embed/rust/src/ui/layout_eckhart/component/hint.rs
new file mode 100644
index 0000000000..28493776eb
--- /dev/null
+++ b/core/embed/rust/src/ui/layout_eckhart/component/hint.rs
@@ -0,0 +1,370 @@
+use crate::{
+    strutil::TString,
+    ui::{
+        component::{text::TextStyle, Component, Event, EventCtx, Label, Never},
+        constant::screen,
+        display::{Color, Icon},
+        event::SwipeEvent,
+        geometry::{Alignment, Alignment2D, Direction, Insets, Offset, Point, Rect},
+        lerp::Lerp,
+        shape::{self, Renderer, Text},
+        util::Pager,
+    },
+};
+
+use super::{super::fonts, theme};
+
+/// Component rendered above ActionBar, showing one of these:
+///     - a task instruction/hint with optional icon, e.g. "Confirm
+///       transaction",
+///     - a page counter e.g. "1 / 3", meaning the first screen of three total.
+///
+/// The instruction has adaptive height, depending on the text length. The
+/// PageCounter is always of minimal component height (40px).
+#[derive(Clone)]
+pub struct Hint<'a> {
+    area: Rect,
+    content: HintContent<'a>,
+    swipe_allow_up: bool,
+    swipe_allow_down: bool,
+    progress: i16,
+    dir: Direction,
+}
+
+#[derive(Clone)]
+enum HintContent<'a> {
+    Instruction(Instruction<'a>),
+    PageCounter(PageCounter),
+}
+
+impl<'a> Hint<'a> {
+    /// default height of the component [px]
+    pub const HEIGHT_MINIMAL: i16 = 40;
+    /// height of the multi line component [px]
+    pub const HEIGHT_MAXIMAL: i16 = 66;
+    /// margins from the edges of the screen [px]
+    const HINT_INSETS: Insets = Insets::sides(24);
+
+    fn from_content(content: HintContent<'a>) -> Self {
+        Self {
+            area: Rect::zero(),
+            content,
+            swipe_allow_down: false,
+            swipe_allow_up: false,
+            progress: 0,
+            dir: Direction::Up,
+        }
+    }
+
+    pub fn new_instruction<T: Into<TString<'static>>>(text: T, icon: Option<Icon>) -> Self {
+        let instruction_component =
+            Instruction::new(text.into(), theme::GREY, icon, Some(theme::GREY_LIGHT));
+        Self::from_content(HintContent::Instruction(instruction_component))
+    }
+    pub fn new_instruction_green<T: Into<TString<'static>>>(text: T, icon: Option<Icon>) -> Self {
+        let instruction_component = Instruction::new(
+            text.into(),
+            theme::GREEN_LIME,
+            icon,
+            Some(theme::GREEN_LIME),
+        );
+        Self::from_content(HintContent::Instruction(instruction_component))
+    }
+
+    pub fn new_page_counter() -> Self {
+        Self::from_content(HintContent::PageCounter(PageCounter::new()))
+    }
+
+    pub fn with_swipe(self, swipe_direction: Direction) -> Self {
+        match swipe_direction {
+            Direction::Up => Self {
+                swipe_allow_up: true,
+                ..self
+            },
+            Direction::Down => Self {
+                swipe_allow_down: true,
+                ..self
+            },
+            _ => self,
+        }
+    }
+
+    pub fn update(&mut self, pager: Pager) {
+        match &mut self.content {
+            HintContent::PageCounter(counter) => {
+                counter.update(pager);
+                self.swipe_allow_down = counter.pager.is_first();
+                self.swipe_allow_up = counter.pager.is_last();
+            }
+            _ => {}
+        }
+    }
+
+    /// Returns the height of the component. In case of the instruction, the
+    /// height is calculated based on the text length.
+    pub fn height(&self) -> i16 {
+        self.content.height()
+    }
+}
+
+impl<'a> Component for Hint<'a> {
+    type Msg = Never;
+
+    fn place(&mut self, bounds: Rect) -> Rect {
+        debug_assert!(bounds.width() == screen().width());
+        debug_assert!(bounds.height() == self.content.height());
+        let bounds = bounds.inset(Self::HINT_INSETS);
+        match &mut self.content {
+            HintContent::Instruction(instruction) => {
+                if let Some(icon) = instruction.icon {
+                    let icon_width = instruction.icon_width();
+                    let text_area = bounds.split_left(icon_width).1;
+                    instruction.label.place(text_area);
+                } else {
+                    instruction.label.place(bounds);
+                }
+            }
+            _ => {}
+        }
+        self.area = bounds;
+        self.area
+    }
+
+    fn event(&mut self, _ctx: &mut EventCtx, event: Event) -> Option<Self::Msg> {
+        match event {
+            Event::Attach(_) => {
+                self.progress = 0;
+            }
+            Event::Swipe(SwipeEvent::Move(dir, progress)) => match dir {
+                Direction::Up if self.swipe_allow_up => {
+                    self.progress = progress;
+                    self.dir = dir;
+                }
+                Direction::Down if self.swipe_allow_down => {
+                    self.progress = progress;
+                    self.dir = dir;
+                }
+                _ => {}
+            },
+            _ => {}
+        };
+
+        None
+    }
+
+    fn render<'s>(&'s self, target: &mut impl Renderer<'s>) {
+        let progress = self.progress as f32 / 1000.0;
+
+        let shift = pareen::constant(0.0).seq_ease_out(
+            0.0,
+            easer::functions::Cubic,
+            1.0,
+            pareen::constant(1.0),
+        );
+
+        let offset = i16::lerp(0, 20, shift.eval(progress));
+
+        let mask = u8::lerp(0, 255, shift.eval(progress));
+
+        let offset = match self.dir {
+            Direction::Up => Offset::y(-offset),
+            Direction::Down => Offset::y(3 * offset),
+            _ => Offset::zero(),
+        };
+
+        target.with_origin(offset, &|target| {
+            self.content.render(self.area, target);
+            shape::Bar::new(self.area)
+                .with_alpha(mask)
+                .with_fg(Color::black())
+                .with_bg(Color::black())
+                .render(target);
+        });
+    }
+}
+
+impl<'a> HintContent<'a> {
+    fn height(&self) -> i16 {
+        match self {
+            HintContent::Instruction(instruction) => instruction
+                .height()
+                .clamp(Hint::HEIGHT_MINIMAL, Hint::HEIGHT_MAXIMAL),
+            HintContent::PageCounter(_) => Hint::HEIGHT_MINIMAL,
+        }
+    }
+
+    fn render<'s>(&'s self, area: Rect, target: &mut impl Renderer<'s>)
+    where
+        's: 'a,
+    {
+        match self {
+            HintContent::Instruction(instruction) => instruction.render(target, area),
+            HintContent::PageCounter(page_counter) => page_counter.render(target, area),
+        }
+    }
+}
+
+// Helper componet used within Hint for instruction/hint rendering.
+#[derive(Clone)]
+struct Instruction<'a> {
+    label: Label<'a>,
+    text_color: Color,
+    icon: Option<Icon>,
+    icon_color: Option<Color>,
+}
+
+impl<'a> Instruction<'a> {
+    /// default style for instruction text
+    const STYLE_INSTRUCTION: &'static TextStyle = &theme::TEXT_SMALL;
+    /// margin between icon and text
+    const ICON_OFFSET: Offset = Offset::x(24); // [px]
+
+    fn new(
+        text: TString<'a>,
+        text_color: Color,
+        icon: Option<Icon>,
+        icon_color: Option<Color>,
+    ) -> Self {
+        let mut text_style = Self::STYLE_INSTRUCTION.clone();
+        text_style.text_color = text_color;
+        Self {
+            label: Label::left_aligned(text, text_style).vertically_centered(),
+            text_color,
+            icon,
+            icon_color,
+        }
+    }
+
+    /// Calculates the width needed for the icon
+    fn icon_width(&self) -> i16 {
+        self.icon
+            .map_or(0, |icon| icon.toif.width() + Self::ICON_OFFSET.x)
+    }
+
+    /// Calculates the height needed for the Instruction text to be rendered.
+    fn height(&self) -> i16 {
+        let text_area_width = screen().inset(Hint::HINT_INSETS).width() - self.icon_width();
+        let calculated_height = self.label.text_height(text_area_width);
+        dbg_print!("Instruction height: {}\n", calculated_height as i16);
+        debug_assert!(calculated_height <= Hint::HEIGHT_MAXIMAL);
+        calculated_height
+    }
+
+    fn render<'s>(&'s self, target: &mut impl Renderer<'s>, area: Rect) {
+        if let Some(icon) = self.icon {
+            shape::ToifImage::new(area.left_center(), icon.toif)
+                .with_align(Alignment2D::CENTER_LEFT)
+                .with_fg(self.icon_color.unwrap_or(self.text_color))
+                .render(target);
+        };
+        // the label got area without the icon in `place` function
+        self.label.render(target);
+    }
+}
+
+/// Helper component used within Hint for page count indication, rendered e.g.
+/// as: '1 / 20'.
+#[derive(Clone)]
+struct PageCounter {
+    pager: Pager,
+}
+
+impl PageCounter {
+    fn new() -> Self {
+        Self {
+            pager: Pager::single_page(),
+        }
+    }
+
+    fn update(&mut self, pager: Pager) {
+        self.pager = pager
+    }
+}
+
+impl PageCounter {
+    fn render<'s>(&'s self, target: &mut impl Renderer<'s>, area: Rect) {
+        let font = fonts::FONT_SATOSHI_REGULAR_22;
+        let (color_num, color_icon) = if self.pager.is_last() {
+            (theme::GREEN_LIGHT, theme::GREEN)
+        } else {
+            (theme::GREY, theme::GREY_DARK)
+        };
+
+        let string_curr = uformat!("{}", self.pager.current() + 1);
+        let string_max = uformat!("{}", self.pager.total());
+
+        // the counter is left aligned
+        let offset_x = Offset::x(4); // spacing between foreslash and numbers
+        let width_num_curr = font.text_width(&string_curr);
+        let width_foreslash = theme::ICON_FORESLASH.toif.width();
+        let width_num_max = font.text_width(&string_max);
+        let width_total = width_num_curr + width_foreslash + width_num_max + 2 * offset_x.x;
+
+        let counter_area = area.inset(Hint::HINT_INSETS);
+        let counter_start_x = counter_area.bottom_left().x;
+        let counter_y = font.vert_center(counter_area.y0, counter_area.y1, "0");
+        let counter_end_x = counter_start_x + width_total;
+        let base_num_curr = Point::new(counter_start_x, counter_y);
+        let base_foreslash = Point::new(counter_start_x + width_num_curr + offset_x.x, counter_y);
+        let base_num_max = Point::new(counter_end_x, counter_y);
+
+        Text::new(base_num_curr, &string_curr, font)
+            .with_align(Alignment::Start)
+            .with_fg(color_num)
+            .render(target);
+        shape::ToifImage::new(base_foreslash, theme::ICON_FORESLASH.toif)
+            .with_align(Alignment2D::BOTTOM_LEFT)
+            .with_fg(color_icon)
+            .render(target);
+        Text::new(base_num_max, &string_max, font)
+            .with_align(Alignment::End)
+            .with_fg(color_num)
+            .render(target);
+    }
+}
+
+#[cfg(feature = "ui_debug")]
+impl<'a> crate::trace::Trace for Hint<'a> {
+    fn trace(&self, t: &mut dyn crate::trace::Tracer) {
+        t.component("Hint");
+        match &self.content {
+            HintContent::Instruction(i) => {
+                t.child("instruction", &i.label);
+            }
+            HintContent::PageCounter(counter) => {
+                t.int("page curr", counter.pager.current().into());
+                t.int("page max", counter.pager.total().into());
+            }
+        }
+    }
+}
+
+#[cfg(test)]
+mod tests {
+    use super::{super::constant, *};
+    use crate::strutil::TString;
+
+    #[test]
+    fn test_instruction_hint_height() {
+        // FIXME: this test is fine but the `screen()` is not returning the right value
+        // for eckhart println!("screen size: {:?}", screen().width());
+
+        let hint_1line = Hint::new_instruction("Test", None);
+        assert_eq!(hint_1line.height(), Hint::HEIGHT_MINIMAL);
+
+        let hint_2lines = Hint::new_instruction(
+            "The word appears multiple times in the backup.",
+            Some(theme::ICON_INFO),
+        );
+        assert_eq!(
+            hint_2lines.height(),
+            Instruction::STYLE_INSTRUCTION.text_font.text_height() * 2
+        );
+
+        let hint_3lines = Hint::new_instruction(
+            "This is very long instruction which will span across at least three lines of the Hint component.",
+            None,
+        );
+        assert_eq!(hint_3lines.height(), Hint::HEIGHT_MAXIMAL,);
+    }
+}
diff --git a/core/embed/rust/src/ui/layout_eckhart/component/mod.rs b/core/embed/rust/src/ui/layout_eckhart/component/mod.rs
index 62e7ed260a..f84fc1f54a 100644
--- a/core/embed/rust/src/ui/layout_eckhart/component/mod.rs
+++ b/core/embed/rust/src/ui/layout_eckhart/component/mod.rs
@@ -2,12 +2,14 @@ pub mod bl_confirm;
 mod button;
 mod error;
 mod header;
+mod hint;
 mod result;
 mod welcome_screen;
 
 pub use button::{Button, ButtonMsg, ButtonStyle, ButtonStyleSheet, IconText};
 pub use error::ErrorScreen;
 pub use header::{Header, HeaderMsg};
+pub use hint::Hint;
 pub use result::{ResultFooter, ResultScreen, ResultStyle};
 pub use welcome_screen::WelcomeScreen;