/* Dynamic viewport height when supported */
.wrap {
  height: 100vh;
  height: 100dvh;
  padding: 1px;
  padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px) + var(--footer-gap));
  display: flex;
  overflow: hidden;
}

.vbox {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0px;
}

/* Footer pinned */
.footer {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  padding-top: 10px;
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.composer {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
