.home{min-height:100vh;display:grid;place-items:center;position:relative;background-image:url(/bg.jpg);background-size:cover;background-position:center}.home__overlay{position:absolute;inset:0;background:#0000008c}.home__card{position:relative;width:min(560px,92vw);padding:28px;border-radius:22px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center}.home__title{margin:0;font-size:2.2rem}.home__subtitle{margin:10px 0 18px;color:#ffffffbf}.home__actions{display:flex;gap:12px;justify-content:center}.form{display:grid;gap:12px;justify-items:center}.input{width:90%;padding:.65rem .8rem;border:1px solid rgba(255,255,255,.18);border-radius:10px;outline:none;background:#00000047;color:var(--text)}.input--bad{border-color:#d94b4bd9}.hint{margin:10px 0 0;color:var(--muted)}.msg{width:90%;margin:6px 0 0;padding:10px 12px;border-radius:12px;border:1px solid var(--border)}.msg--error{background:#d94b4b1f;border-color:#d94b4b40}.msg--ok{background:#5b8cff1f;border-color:#5b8cff40}.passwordRow{position:relative;width:90%;display:flex}.input--grow{width:100%}.passwordPopover{position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);background:#0a0e14f2;border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:12px;min-width:220px;z-index:20;box-shadow:0 10px 30px #00000059}.topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:#ffffff0a}.brand{font-weight:700;letter-spacing:.2px}.content{margin-top:16px}.content--narrow{max-width:820px;margin-inline:auto}.lib{min-height:100vh;background:var(--bg)}.lib__topbar{position:absolute;top:24px;left:24px;right:24px;z-index:10;background:#0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.lib__message{text-align:center;padding:48px 24px;color:var(--muted)}.lib__section{padding:0 24px;margin-bottom:24px}.lib__section-title{font-size:1.3rem;font-weight:600;margin:0 0 12px}.hero{position:relative;width:100%;height:70vh;min-height:450px;overflow:hidden}.hero__backdrop{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.hero__gradient{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to top,var(--bg) 0%,transparent 60%),linear-gradient(to right,rgba(0,0,0,.6) 0%,transparent 50%)}.hero__content{position:absolute;bottom:48px;left:48px;z-index:2;max-width:600px}.hero__title{font-size:clamp(2rem,4vw,3.5rem);font-weight:700;margin:0 0 8px}.hero__meta{display:flex;gap:16px;color:var(--muted);font-size:.95rem;margin-bottom:6px}.hero__rating{color:#fbbf24}.hero__genres{color:var(--muted);font-size:.9rem;margin-bottom:12px;letter-spacing:.3px}.hero__overview{color:var(--muted);font-size:.9rem;line-height:1.5;margin:0 0 20px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.btn--play{background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.3);color:var(--text);padding:14px 32px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer}.btn--play:hover{background:#ffffff40}.card-content{width:160px;flex-shrink:0;border-radius:12px;overflow:hidden;background:var(--card);border:1px solid var(--border);transition:transform .2s ease,border-color .2s ease}.card-content--clickable{cursor:pointer}.card-content--clickable:hover{transform:scale(1.05);border-color:var(--primary);z-index:2}.card-content__poster{position:relative;aspect-ratio:2 / 3;overflow:hidden;background:#0000004d}.card-content__img{width:100%;height:100%;object-fit:cover;display:block}.card-content__placeholder{width:100%;height:100%;display:grid;place-items:center;font-size:2.5rem;font-weight:700;color:var(--muted);background:linear-gradient(135deg,#5b8cff1a,#0000004d)}.card-content__rating{position:absolute;top:0;right:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fbbf24;font-size:.75rem;padding:2px 8px;border-radius:0 0 0 8px}.card-content__progress{position:absolute;bottom:0;left:0;right:0;height:4px;background:#ffffff26}.card-content__progress-bar{height:100%;background:var(--primary);border-radius:2px}.card-content__info{padding:8px 10px}.card-content__title{font-weight:600;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-content__year{font-size:.75rem;color:var(--muted)}.lib__row{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;padding:10px 0 8px;-webkit-overflow-scrolling:touch}.lib__row>*:first-child{margin-left:10px}.lib__row>*:last-child{margin-right:10px}.lib__row>*{scroll-snap-align:start}.lib__row::-webkit-scrollbar{height:6px}.lib__row::-webkit-scrollbar-track{background:transparent}.lib__row::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.lib__row::-webkit-scrollbar-thumb:hover{background:#ffffff40}.lib__loading{padding:0}.lib__skeleton-hero{height:70vh;min-height:450px;background:linear-gradient(110deg,var(--card) 30%,rgba(255,255,255,.08) 50%,var(--card) 70%);background-size:200% 100%;animation:shimmer 1.5s infinite}.lib__skeleton-row{height:280px;margin:24px;border-radius:12px;background:linear-gradient(110deg,var(--card) 30%,rgba(255,255,255,.08) 50%,var(--card) 70%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media(max-width:768px){.hero{height:50vh;min-height:350px}.hero__content{bottom:32px;left:24px}.card-content{width:130px}}@media(max-width:480px){.hero{height:40vh;min-height:280px}.hero__content{bottom:24px;left:16px}.lib__section{padding:0 16px}.card-content{width:120px}}.gamesPage{min-height:100vh;padding:2rem;background:radial-gradient(1200px 600px at 30% 20%,rgba(255,255,255,.08),transparent),radial-gradient(900px 500px at 70% 60%,rgba(255,255,255,.06),transparent),linear-gradient(135deg,#0b1020,#0b1b2a);color:#fff}.gamesHeader{max-width:1100px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.gamesTitle{margin:0;font-size:2rem;letter-spacing:.5px}.gamesSubtitle{margin:.35rem 0 0;opacity:.85}.gamesGrid{max-width:1100px;margin:0 auto;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.gameCard{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:14px;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gameCoverWrap{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#00000040}.gameCover{width:100%;height:100%;object-fit:cover;display:block}.gameCardBody{padding:.9rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.gameName{font-weight:600;line-height:1.2}.gameCoverPlaceHolder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f133,#8b5cf633)}.gameCoverPlaceHolder span{font-size:3rem;font-weight:700;color:#ffffff4d}.gameType{font-size:3rem;text-transform:uppercase;letter-spacing:.08em;color:#fff6}.gamesLoading,.gamesError{text-align:center;max-width:1100px;margin:2rem auto;color:#fff9}.gamesError{color:#f87171}.streamPage{min-height:100vh;background:#0a0a0f;display:flex;flex-direction:column}.streamHeader{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06)}.streamInfo{display:flex;align-items:center;gap:1rem}.streamStatus{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;padding:.25rem .6rem;border-radius:4px}.streamStatus--connecting{color:#fbbf24;background:#fbbf241a}.streamStatus--connected{color:#34d399;background:#34d3991a}.streamStatus--disconnected,.streamStatus--error{color:#f87171;background:#f871711a}.streamFps{font-size:.8rem;color:#ffffff80;font-variant-numeric:tabular-nums}.streamContainer{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:1rem}.streamCanvas{max-width:100%;max-height:calc(100vh - 80px);border-radius:4px;cursor:crosshair;image-rendering:auto}.streamOverlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#000c;color:#ffffffb3;font-size:1.1rem}.streamOverlay--error{color:#f87171}.streamOverlay button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1.2rem;border-radius:6px;cursor:pointer;font-size:.9rem}.streamOverlay button:hover{background:#fff3}:root{--bg: #0b0f14;--card: rgba(255, 255, 255, .06);--border: rgba(255, 255, 255, .12);--text: rgba(255, 255, 255, .92);--muted: rgba(255, 255, 255, .7);--primary: #5b8cff;--danger: #d94b4b}*{box-sizing:border-box}html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}a{color:inherit}.page{min-height:100vh;padding:24px}.page--center{display:grid;place-items:start center;padding-top:72px}.card{width:min(520px,92vw);background:var(--card);border:1px solid var(--border);border-radius:18px;padding:22px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.card__title{margin:0 0 14px;text-align:center}.muted{color:var(--muted)}.row{display:flex;gap:12px;align-items:center}.row--center{justify-content:center}.btn{border:1px solid var(--border);background:#ffffff0a;color:var(--text);padding:10px 14px;border-radius:12px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:hover{background:#ffffff14}.btn--primary{background:#5b8cff2e;border-color:#5b8cff59}.btn--danger{background:#d94b4b2e;border-color:#d94b4b59}.btn--ghost{background:#ffffff05}.btn--half{width:45%}
