/* ===== CloudGamingPro — Browse Games ===== */

/* page-level spacing under fixed nav */
.games-page{padding-top:88px}

/* ===== library hero / featured ===== */
.lib-hero{position:relative;padding:54px 0 40px;overflow:hidden}
.lib-hero .glow{position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:760px;height:420px;border-radius:50%;background:rgba(124,92,255,.18);filter:blur(130px);pointer-events:none}
.lib-head{position:relative;z-index:2;text-align:center;margin-bottom:38px}
.lib-head .eyebrow{margin-bottom:12px}
.lib-head h1{font-size:clamp(34px,5vw,56px);font-weight:800;line-height:1.05;margin-bottom:14px}
.lib-head p{color:var(--muted);font-size:17px;max-width:520px;margin:0 auto}

/* featured banner */
.featured{position:relative;z-index:2;border-radius:24px;overflow:hidden;height:340px;display:flex;align-items:flex-end;box-shadow:0 40px 80px -30px rgba(0,0,0,.8),0 0 0 1px var(--line) inset}
.featured img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.featured .scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,7,13,.92) 8%,rgba(8,7,13,.55) 45%,transparent 80%),linear-gradient(0deg,rgba(8,7,13,.6),transparent 50%)}
.featured-body{position:relative;z-index:2;padding:42px 46px;max-width:560px}
.featured .tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--violet-br);background:rgba(124,92,255,.14);border:1px solid rgba(124,92,255,.3);border-radius:99px;padding:6px 14px;margin-bottom:16px}
.featured h2{font-size:clamp(28px,3.5vw,40px);font-weight:800;line-height:1.04;margin-bottom:12px}
.featured p{color:rgba(255,255,255,.72);font-size:15px;max-width:420px;margin-bottom:22px}
.featured .meta{display:flex;gap:18px;margin-bottom:24px;flex-wrap:wrap}
.featured .meta span{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px}
.featured .meta svg{width:15px;height:15px;stroke:var(--cyan);stroke-width:1.7;fill:none}

/* ===== toolbar: search + filters ===== */
.lib-toolbar{position:sticky;top:64px;z-index:50;padding:18px 0;background:rgba(8,7,13,.78);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);margin-bottom:36px}
.lib-toolbar .wrap{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.search{position:relative;flex:1;min-width:240px}
.search svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:18px;height:18px;stroke:var(--faint);stroke-width:1.8;fill:none;pointer-events:none}
.search input{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:13px 16px 13px 46px;color:#fff;font-family:inherit;font-size:15px;outline:none;transition:border-color .2s,background .2s}
.search input::placeholder{color:var(--faint)}
.search input:focus{border-color:rgba(124,92,255,.5);background:rgba(124,92,255,.06)}
.sortbox{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted)}
.sortbox select{background:var(--surface);border:1px solid var(--line);border-radius:10px;color:#fff;font-family:inherit;font-size:14px;padding:10px 14px;outline:none;cursor:pointer}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.chip{font-family:inherit;font-size:13.5px;font-weight:600;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:99px;padding:9px 18px;cursor:pointer;transition:all .22s;white-space:nowrap}
.chip:hover{color:#fff;border-color:rgba(255,255,255,.2)}
.chip.active{color:#fff;background:linear-gradient(120deg,var(--violet),var(--violet-br));border-color:transparent;box-shadow:0 8px 22px -10px rgba(124,92,255,.8)}

/* ===== grid ===== */
.lib-count{font-size:13px;color:var(--faint);margin-bottom:18px}
.lib-count b{color:#fff}
.lib-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.tile{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:616/353;background:var(--surface);border:1px solid var(--line);color:#fff;cursor:pointer;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .3s}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.tile:hover{transform:translateY(-6px);border-color:rgba(124,92,255,.4);box-shadow:0 28px 50px -22px rgba(124,92,255,.6);z-index:2}
.tile:hover img{transform:scale(1.07)}
.tile .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:14px;background:linear-gradient(to top,rgba(8,7,13,.94),rgba(8,7,13,.2) 55%,transparent);opacity:0;transition:opacity .25s}
.tile:hover .ov{opacity:1}
.tile .ov h3{font-size:15px;font-weight:700;margin-bottom:8px}
.tile .ov .play{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-size:12.5px;font-weight:700;color:#fff;background:linear-gradient(120deg,var(--violet),var(--violet-br));border-radius:9px;padding:8px 14px;align-self:flex-start;transform:translateY(6px);transition:transform .3s .04s,opacity .3s;opacity:0}
.tile:hover .ov .play{transform:none;opacity:1}
.tile .ov .play svg{width:13px;height:13px;fill:#fff}
.tile .corner{position:absolute;top:10px;left:10px;z-index:2;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 9px;border-radius:7px;background:rgba(8,7,13,.7);backdrop-filter:blur(6px);border:1px solid var(--line)}
.tile .corner.free{color:#34d399}
.tile .corner.new{color:var(--cyan)}
.tile .store{position:absolute;bottom:10px;right:10px;z-index:2;font-size:10px;font-weight:600;color:var(--faint);background:rgba(8,7,13,.6);backdrop-filter:blur(6px);border:1px solid var(--line);border-radius:6px;padding:4px 8px;transition:opacity .25s}
.tile:hover .store{opacity:0}
.tile.hidden{display:none}

/* genre label under name */
.tile .ov .gtag{font-size:11px;color:var(--faint);margin-bottom:10px}

/* load more */
.lib-more{text-align:center;margin:50px 0 10px}

/* empty state */
.lib-empty{text-align:center;padding:70px 0;color:var(--muted);display:none}
.lib-empty.show{display:block}
.lib-empty svg{width:46px;height:46px;stroke:var(--faint);stroke-width:1.5;fill:none;margin-bottom:16px}

@media(max-width:980px){.lib-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.lib-grid{grid-template-columns:repeat(2,1fr)}.featured{height:300px}.featured-body{padding:28px}}
@media(max-width:460px){.lib-grid{grid-template-columns:1fr}}
