@layer components {
  .app-page {
    min-block-size: 100dvh;
    display: flex;
    flex-direction: column;
    background-color: var(--color-canvas);
    padding-block-start: var(--safe-top);
    padding-block-end: calc(5rem + var(--safe-bottom));
  }

  .app-page__content {
    flex: 1;
    overflow-y: auto;
    padding: var(--space-md);

    &--no-padding {
      padding: 0;
    }
  }
}
