:root { --top-buffer: 80px; /* space for header */ --bottom-buffer: 60px; /* space for footer */ --content-height: 800px; /* internal height of iframe content */ } #iframe-wrapper { position: relative; width: 100%; height: calc(100vh - var(--top-buffer) - var(--bottom-buffer)); overflow: hidden; } #iframe-wrapper iframe { width: 100%; height: var(--content-height); border: none; transform-origin: top center; transform: scale(var(--scale-factor)); }