.loading { position : absolute; color : #999; top : 0px; left : 0px; height : 100%; width : 100%; z-index : 32; text-align : center; background : white; padding : 16px; font-size : 18px; display : table; } .loading > div { display : table-cell; vertical-align : middle; } .header { top : 5px; left : 0px; width : 100%; height : 24px; } .footer { bottom : 5px; left : 0px; width : 100%; height : 24px; } .header, .footer { position : absolute; font-size : 13px; display : table; padding-left : 10px; padding-right : 10px; color : #999; } .header > *, .footer > * { display : table-cell; vertical-align : middle; } .header .title { margin-left : 30px; } .footer .location { cursor : pointer; text-align : right; } .toolbar { text-align : right; } .toolbar > * { margin-left : 5px; } #reader { position : absolute; top : 32px; bottom : 32px; left : 96px; right : 96px; } @media (max-width: 767px) { #reader { left : 32px; right : 32px; } } ul.toc_list { height : 250px; overflow : auto; }