:root{color:#1c2430;background:#f8f6f0;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:linear-gradient(180deg,#ffffffb8,#fff0),#f8f6f0}button,a{font:inherit}button{min-height:44px;border:2px solid #1c2430;border-radius:6px;padding:.7rem 1rem;color:#fff;background:#315f52;cursor:pointer}button:hover{background:#264b41}button:focus-visible,a:focus-visible,iframe:focus-visible{outline:3px solid #d78b28;outline-offset:3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{min-height:100vh}.site-header{border-bottom:1px solid #ded8cc;background:#ffffffd1}.brand-link{display:flex;width:min(72rem,100%);align-items:center;gap:.75rem;margin:0 auto;padding:.9rem 1rem;color:inherit;text-decoration:none}.brand-mark{display:grid;width:2.25rem;height:2.25rem;place-items:center;border:2px solid #1c2430;border-radius:6px;color:#fff;background:#9b4d35;font-weight:800}.brand-name,.brand-note{display:block}.brand-name{font-weight:800}.brand-note{color:#5a6470;font-size:.9rem}.page,.play-page{width:min(72rem,100%);margin:0 auto;padding:1.5rem 1rem 2.5rem}.page-intro{margin:1rem 0 1.5rem}.page-intro h1{margin:0;font-size:clamp(1.6rem,3vw,2.35rem);line-height:1.1}.page-intro p,.game-card p{color:#4f5b66;line-height:1.5}.system-message{border-left:5px solid #315f52;padding:.75rem 1rem;background:#fff}.system-message.error{border-color:#a23f2d}.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(20rem,100%),22rem));gap:1rem}.game-card{display:grid;min-height:15rem;gap:1rem;align-content:space-between;border:1px solid #ded8cc;border-radius:8px;padding:1rem;background:#fff}.game-card h2{margin:0 0 .5rem;font-size:1.25rem}.game-card p{margin:0}.game-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin:0}.game-facts div{min-width:0}.game-facts dt{color:#6a5c50;font-size:.78rem;font-weight:800;text-transform:uppercase}.game-facts dd{margin:.2rem 0 0;overflow-wrap:anywhere}.play-page{width:min(80rem,100%);display:grid;gap:.85rem;padding-top:1.15rem}.player-toolbar{display:grid;grid-template-areas:"back status";grid-template-columns:auto auto;justify-content:space-between;gap:1rem;align-items:center}.player-back{grid-area:back;justify-self:start}.back-button{color:#1c2430;background:#fff}.back-button:hover{background:#f0ebe2}.status-pill{grid-area:status;min-width:8rem;border:1px solid #ded8cc;border-radius:999px;padding:.55rem .8rem;background:#fff;text-align:center;font-weight:700}.status-pill.ready{border-color:#315f52}.status-pill.complete{border-color:#315f52;background:#e5f0ea}.status-pill.error{border-color:#a23f2d;background:#f7e3df}.game-frame{width:100%;height:clamp(40rem,calc(100svh - 8.75rem),45rem);min-height:40rem;border:1px solid #cfc7ba;border-radius:8px;background:#fff}@media(max-width:720px){.player-toolbar{grid-template-columns:auto minmax(7rem,auto);justify-content:space-between;gap:.75rem}.status-pill{min-width:7rem;padding-inline:.85rem}.game-frame{height:clamp(36rem,calc(100svh - 15rem),40rem);min-height:36rem}}@media(max-width:460px){.page,.play-page,.brand-link{padding-inline:.85rem}}
