#app{flex-direction:column;width:100%;height:100vh;display:flex;overflow:hidden}.landing{box-sizing:border-box;flex-direction:column;align-items:center;width:100%;height:100%;padding:2rem;display:flex;overflow-y:auto}.landing-title{color:wheat;text-shadow:2px 2px 4px #0009;letter-spacing:.05em;margin:0 0 2rem;font-family:Georgia,serif;font-size:2rem}.game-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;width:100%;max-width:900px;display:grid}.game-card{cursor:pointer;color:inherit;font:inherit;background:#00000059;border:2px solid #f5deb340;border-radius:10px;flex-direction:column;align-items:center;gap:.6rem;padding:.75rem;transition:transform .15s,border-color .15s,box-shadow .15s;display:flex}.game-card:hover{border-color:#f5deb3b3;transform:translateY(-4px);box-shadow:0 8px 20px #00000080}.game-card-image{aspect-ratio:1;background:#0003;border-radius:6px;width:100%;overflow:hidden}.game-card-image img{object-fit:cover;width:100%;height:100%;display:block}.game-card-placeholder{background:#ffffff0d;width:100%;height:100%}.game-card-label{color:wheat;text-align:center;text-shadow:1px 1px 3px #000000b3;font-family:Georgia,serif;font-size:.95rem}.loading{justify-content:center;align-items:center;width:100%;height:100%;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{border:5px solid #f5deb333;border-top-color:wheat;border-radius:50%;width:56px;height:56px;animation:.9s linear infinite spin}.wooden-table{background-color:#5c3216;background-image:linear-gradient(90deg,#000000b3 1px,#0000 1px),linear-gradient(90deg,#0000 1px,#ffffff14 2px,#0000 3px),repeating-linear-gradient(12deg,#0000,#0000 8px,#0000000a 8px 15px),repeating-linear-gradient(-8deg,#0000,#0000 4px,#00000008 4px 6px);background-size:120px 100%,120px 100%,100% 100%,100% 100%}.felt-playmat{background-color:#2e6b3b;background-image:repeating-radial-gradient(circle,#0000 0,#0000000d 1px,#0000 2px);background-size:4px 4px;border-radius:12px;width:90%;height:90%;margin:5%;box-shadow:inset 0 8px 15px #0009}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400}html,body{height:100%;margin:0;padding:0;overflow:hidden}
