:root{color:#fff;background:#303b43;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#303b43}a{color:inherit}.skip-link{position:fixed;z-index:100;top:.75rem;left:.75rem;padding:.7rem 1rem;transform:translateY(-160%);border-radius:.4rem;color:#fff;background:#143b63}.skip-link:focus{transform:translateY(0)}.site-header{color:#303b43;background:#f1f2f3;border-bottom:4px solid #be1627}.header-inner,.magazine-shell,footer{width:min(100% - 2rem,1600px);margin-inline:auto}.header-inner{min-height:86px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.school-link{display:inline-flex;align-items:center;gap:.8rem;text-decoration:none}.school-link img{width:auto;height:70px;display:block}.header-actions{display:flex;align-items:center;gap:.7rem}.back-link,.pdf-link{padding:.65rem .9rem;border:1px solid currentColor;border-radius:.4rem;font-weight:700;text-decoration:none}.back-link:hover,.pdf-link:hover{background:#fff}.magazine-shell{padding-block:.75rem 0}.pdf-link{color:#fff;border-color:#be1627;background:#be1627;white-space:nowrap}.pdf-link:hover{color:#9f1020}.viewer{min-height:calc(100dvh - 102px);display:grid;grid-template-rows:1fr auto;place-items:center;overflow:hidden;padding:0 clamp(.5rem,2vw,1.5rem) 1rem;border-radius:0;background:#303b43}.status{display:flex;align-items:center;gap:.7rem;color:#fff}.status[hidden]{display:none}.status.error{max-width:620px;display:grid;padding:1.2rem;border:1px solid #f4c7c7;border-radius:.5rem;color:#4c1111;background:#fff2f2}.spinner{width:1.2rem;height:1.2rem;border:2px solid rgb(255 255 255 / 35%);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.book{width:100%;max-height:calc(100dvh - 190px);margin:auto}.page{overflow:hidden;background:#fff;box-shadow:inset 0 0 0 1px #d7dce0}.page canvas{width:100%;height:100%;display:block}.controls{z-index:5;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:1.2rem}.controls[hidden]{display:none}.controls button,.controls output{min-height:44px;display:inline-grid;place-items:center;border-radius:.4rem;color:#fff}.controls button{min-width:44px;display:inline-flex;justify-content:center;gap:.3rem;padding:.55rem .8rem;border:1px solid rgb(255 255 255 / 38%);background:#ffffff14;cursor:pointer;font:inherit;font-weight:700}.controls button:hover{background:#ffffff2e}.controls output{min-width:145px;padding-inline:.5rem}.fullscreen-button{margin-left:.5rem}.fullscreen-button[hidden]{display:none}.fullscreen-button svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:2.25;stroke-linecap:round;stroke-linejoin:round}.fullscreen-button .icon-collapse,.fullscreen-button.is-fullscreen .icon-expand{display:none}.fullscreen-button.is-fullscreen .icon-collapse{display:block}.viewer:fullscreen,.viewer:-webkit-full-screen{width:100%;height:100%;min-height:100dvh;padding:1rem;background:#303b43}.viewer:fullscreen .book,.viewer:-webkit-full-screen .book{max-width:none!important;max-height:none}.viewer:fullscreen .controls,.viewer:-webkit-full-screen .controls{margin-top:.75rem}:focus-visible{outline:3px solid #f7c84d;outline-offset:3px}.help-text{margin:1rem 0;color:#fff;text-align:center}footer{display:flex;justify-content:space-between;gap:1rem;padding-block:1.5rem 2rem;border-top:1px solid rgb(255 255 255 / 25%);color:#fff;font-size:.9rem}footer p{margin:0}footer div{display:flex;gap:1rem}@media(min-width:900px)and (min-height:650px){#app{height:100dvh;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden}.magazine-shell{min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;padding-top:.5rem}.viewer{min-height:0;height:100%}.book{max-height:calc(100dvh - 260px)}.help-text{margin-block:.5rem}footer{padding-block:.75rem 1rem}}@media(max-width:680px){.header-inner{min-height:68px}.school-link img{height:52px}.back-link{display:none}.pdf-link{padding:.55rem .7rem;font-size:.88rem;text-align:center}.viewer{min-height:calc(100dvh - 80px);padding:0 0 .75rem}.book{max-height:calc(100dvh - 160px)}.controls button span{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}.controls output{min-width:120px;font-size:.88rem}footer{align-items:flex-start;flex-direction:column}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.01ms!important}}
