.app { display: flex; flex-flow: column nowrap; grid-template-rows: auto 1fr; height: 100vh; overflow: hidden; } .main { display: flex; flex-flow: row nowrap; flex-grow: 1; overflow: hidden; } .header { font-size: 1.2em; display: flex; flex-flow: row nowrap; align-items: center; justify-content: space-between; background: black; color: white; padding: 1em; a { color: white; } } .sidebar { width: calc((6 / 16) * 100%); height: 100%; grid-area: sidebar; border-right: 1px solid black; overflow-y: auto; li { border-bottom: 1px solid gray; } } .details { width: calc((10 / 16) * 100%); overflow: hidden; height: 100%; } .noRequest, .noRequestSelected { width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; }