*,
*:before,
*:after {
  box-sizing: inherit;
}

html {
  box-sizing: border-box;
  background: black;
  height: 100%;
}

body {
  height: 100%;
}

* {
  margin: 0;
}

main {
  display: grid;
  grid-template-rows: minmax(32px, 1fr) minmax(320px, 640px) minmax(32px, 1fr);
  height: 100%;
}

.forecast {
  grid-row: 2;
  display: grid;
  grid-template-columns: minmax(32px, 1fr) minmax(320px, 1080px) minmax(32px, 1fr);
}
.forecast__graph {
  grid-column: 2;
  display: flex;
  gap: 10px;
  overflow-x: scroll;
}
.forecast__graph > * {
  display: grid;
  grid-template-rows: repeat(10, 1fr);
  width: 100px;
  flex-shrink: 0;
}
.forecast__graph > * > * {
  background: white;
  grid-row: var(--bar-height, -1)/-1;
}