:root{--bg-base:#0f0f13;--bg-card:#16161a;--bg-elevated:#1c1c22;--bg-highest:#222228;--surf-base:#242429;--surf-elevated:#2a2a32;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--radius-full:9999px;--border-subtle:#fffffe0f;--border-base:#fffffe1a;--border-strong:#fffffe29;--text-primary:#fffffe;--text-secondary:#94a1b2;--text-muted:#9fa4b0;--accent-primary:#7f5af0;--accent-hover:#9b7ef8;--progress-primary:#2cb67d;--progress-hover:#3dd68c;--danger-primary:#ef4444;--danger-muted:#ef44441f;--warning-primary:#f59e0b;--warning-muted:#f59e0b80;--stroke-base:#010101;--sidebar-width:224px;--topbar-height:52px;--font-display:"Oswald", sans-serif;--font-body:"Exo 2", sans-serif;--font-mono:"JetBrains Mono", monospace;--ease-default:cubic-bezier(.16,1,.3,1);--gradient-progress:linear-gradient(90deg, var(--accent-primary), var(--progress-primary))}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{background:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);min-height:100vh;overflow-x:hidden}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}*{-webkit-tap-highlight-color:transparent}body.menu-open{overflow:hidden}:focus{outline:none}:focus-visible{outline:2px solid var(--accent-hover);outline-offset:2px;border-radius:var(--radius-sm)}.cl-checkbox:focus-visible{outline-offset:4px}body:before{content:"";z-index:0;pointer-events:none;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surf-elevated);border-radius:2px}.shell{z-index:1;min-height:100vh;display:flex;position:relative}.sb-overlay{display:none}.sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border-base);z-index:200;transition:transform .3s var(--ease-default);flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;bottom:0;left:0}body.sidebar-closed .sidebar{transform:translate(-100%)}.sidebar:after{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#0000000f 3px 4px);position:absolute;inset:0}.sb-logo{border-bottom:1px solid var(--border-base);padding:22px 20px 18px;position:relative}.sb-close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-md);z-index:1;background:0 0;border:none;justify-content:center;align-items:center;font-size:22px;line-height:1;transition:background-color .15s,color .15s;display:none;position:absolute;top:18px;right:18px}.sb-close:hover{background:var(--surf-base);color:var(--accent-primary)}.sb-logo-sys{font-family:var(--font-mono);color:var(--accent-primary);letter-spacing:.2em;text-transform:uppercase;opacity:.8;margin-bottom:7px;font-size:9px}.sb-logo-mark{font-family:var(--font-display);letter-spacing:.06em;color:var(--text-primary);font-size:30px;font-weight:900;line-height:1}.sb-logo-mark span{color:var(--accent-primary)}.sb-logo-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.12em;margin-top:5px;font-size:9px}.sb-logo:before{content:"";border-top:1.5px solid var(--accent-primary);border-right:1.5px solid var(--accent-primary);opacity:.5;width:9px;height:9px;position:absolute;top:12px;right:16px}.sb-nav{flex:1;padding:14px 10px;overflow-y:auto}.sb-sec{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);align-items:center;gap:8px;margin:18px 0 6px;padding:0 8px;font-size:9px;display:flex}.sb-sec:after{content:"";background:var(--border-base);flex:1;height:1px}.sb-sec:first-child{margin-top:2px}.sb-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;text-align:left;letter-spacing:.04em;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:13px;font-weight:600;transition:all .15s;display:flex;position:relative;overflow:hidden}.sb-item:hover{background:var(--surf-base);color:var(--text-primary)}.sb-item.on{color:var(--accent-primary);background:#7f5af01f}.sb-item.on:before{content:"";background:var(--accent-primary);border-radius:0 2px 2px 0;width:2px;position:absolute;top:20%;bottom:20%;left:0;box-shadow:0 0 8px #7f5af099}.sb-ic{text-align:center;opacity:.7;width:18px;font-size:14px}.sb-lib-icon-img{border-radius:var(--radius-sm);object-fit:cover;opacity:.9;width:18px;height:18px}.sb-lib-item{border-radius:var(--radius-md);align-items:center;transition:background .15s;display:flex;position:relative}.sb-lib-item:hover,.sb-lib-item:focus-within{background:var(--surf-base)}.sb-lib-link{cursor:pointer;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:9px;min-width:0;padding:6px 12px;display:flex}.sb-lib-nm{white-space:nowrap;text-overflow:ellipsis;letter-spacing:.02em;color:var(--text-secondary);flex:1;font-size:12px;font-weight:600;overflow:hidden}.sb-lib-pct{font-family:var(--font-mono);color:var(--progress-primary);font-size:11px;transition:opacity .15s}.sb-lib-remove{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;margin-right:4px;padding:4px;font-size:12px;line-height:1;transition:color .15s,background .15s;display:none}.sb-lib-remove:hover{color:var(--danger-primary);background:var(--danger-muted)}.sb-lib-item:hover .sb-lib-pct,.sb-lib-item:focus-within .sb-lib-pct{display:none}.sb-lib-item:hover .sb-lib-remove,.sb-lib-item:focus-within .sb-lib-remove{display:block}.sb-footer{border-top:1px solid var(--border-base);padding:12px 18px}.sb-footer-row{font-family:var(--font-mono);color:var(--text-muted);align-items:center;gap:8px;font-size:10px;display:flex}.sb-dot{border-radius:var(--radius-full);background:var(--progress-primary);width:6px;height:6px;animation:2.4s infinite blink;box-shadow:0 0 8px #2cb67db3}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}@media (width<=768px){.sidebar{border-right:none;width:100vw;transform:translate(-100%)}.sidebar.open{transform:none}.sb-close{display:flex}}.main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;display:flex}body.sidebar-closed .main{margin-left:0}.topbar{z-index:100;height:var(--topbar-height);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-base);background:#0f0f13e6;align-items:center;gap:14px;padding:0 24px;display:flex;position:sticky;top:0;overflow:visible}.tb-hamburger{border-radius:var(--radius-md);background:var(--surf-base);border:1px solid var(--border-base);flex-direction:column;gap:4px;padding:7px;transition:background-color .15s,border-color .15s;display:flex}.tb-hamburger:hover{background:var(--surf-elevated);border-color:var(--accent-primary)}.tb-hamburger span{background:var(--text-secondary);border-radius:1px;width:16px;height:2px;display:block}.tb-bc{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;flex:1;align-items:center;gap:6px;min-width:0;max-width:calc(50% - 180px);font-size:11px;display:flex}.tb-bc-prefix{color:var(--accent-primary);flex-shrink:0}.tb-back{cursor:pointer;white-space:nowrap;color:var(--accent-primary);flex-shrink:0;transition:color .15s}.tb-back:hover{color:var(--accent-hover)}.tb-sep{color:var(--text-muted);opacity:.4;flex-shrink:0}.tb-current{white-space:nowrap;text-overflow:ellipsis;color:var(--text-muted);min-width:0;overflow:hidden}.tb-search{background:var(--surf-base);border:1px solid var(--border-base);border-radius:var(--radius-md);align-items:center;gap:8px;width:340px;height:33px;padding:0 12px;transition:border-color .2s,box-shadow .2s;display:flex;position:absolute;left:50%;transform:translate(-50%)}.tb-search:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #7f5af026}.tb-search-ic{color:var(--text-muted);font-size:13px}.tb-search input{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:.04em;background:0 0;border:none;outline:none;width:100%;font-size:12px}.tb-search input::placeholder{color:var(--text-muted)}.tb-search-dropdown{background:var(--bg-elevated);border:1px solid var(--border-base);border-radius:var(--radius-md);z-index:110;max-height:360px;padding:6px;display:none;position:absolute;top:calc(100% + 8px);left:0;right:0;overflow-y:auto;box-shadow:0 12px 32px #00000073}.tb-search[data-open=true] .tb-search-dropdown{display:block}.tb-result{border-radius:var(--radius-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:8px 10px;transition:background-color .12s;display:flex}.tb-result:hover{background:var(--surf-elevated)}.tb-result.is-active{background:var(--surf-elevated);outline:1px solid var(--accent-primary);outline-offset:-1px}.tb-result-icon{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:36px;height:36px}.tb-result-body{flex:1;min-width:0}.tb-result-title{font-family:var(--font-body);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.tb-result-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:10px;overflow:hidden}.tb-result-empty{text-align:center;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;padding:14px 12px;font-size:11px}@media (width<=768px){.main{margin-left:0}.topbar{padding:0 14px}.tb-search{flex:1;width:auto;min-width:0;position:static;transform:none}.tb-search-dropdown{top:calc(var(--topbar-height) + 8px);width:auto;position:fixed;left:12px;right:12px}}.tb-section{padding:4px 0 6px}.tb-section+.tb-section{border-top:1px solid var(--surf-elevated);margin-top:4px;padding-top:6px}.tb-section-title{font-family:var(--font-mono);letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;padding:6px 10px 4px;font-size:10px}.tb-result-item .tb-result-icon{flex-shrink:0;width:28px;height:28px}.tb-result-item .tb-result-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.tb-result-item .tb-result-sub{font-family:var(--font-mono);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:10px;overflow:hidden}.tb-indexing{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;align-items:center;gap:8px;padding:8px 10px;font-size:11px;display:flex}.tb-indexing:before{content:"";border:1.5px solid var(--text-muted);border-top-color:var(--accent-primary);border-radius:50%;flex-shrink:0;width:10px;height:10px;animation:.9s linear infinite tb-spin}.tb-result-badge{font-family:var(--font-mono);letter-spacing:.12em;border-radius:var(--radius-sm);flex-shrink:0;align-self:center;padding:3px 7px;font-size:9px;font-weight:600}.tb-result-badge--guide{color:var(--accent-hover);background:#7f5af01f;border:1px solid #7f5af040}@keyframes tb-spin{to{transform:rotate(360deg)}}.page{padding:28px 28px 80px}.lib-section{margin-bottom:36px}.lib-grid{grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:10px;display:grid}.catalog-grid{grid-template-columns:repeat(auto-fill,minmax(296px,1fr));gap:14px;display:grid}@media (width<=768px){.page{padding:18px 14px 60px}.catalog-grid,.lib-grid{grid-template-columns:1fr}}.page-loader{height:calc(100vh - 120px);color:var(--text-muted);font-family:var(--font-mono);letter-spacing:.2em;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.pl-spinner{border:2px solid var(--surf-elevated);border-top-color:var(--accent-primary);border-radius:var(--radius-full);width:40px;height:40px;animation:1s linear infinite spin;position:relative}.pl-spinner:after{content:"";border:1px solid var(--accent-primary);border-radius:var(--radius-full);opacity:.3;animation:1.5s ease-out infinite pulse;position:absolute;inset:-6px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%{opacity:.3;transform:scale(1)}to{opacity:0;transform:scale(1.4)}}.stat-strip{border:1px solid var(--border-base);border-radius:var(--radius-lg);grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:32px;display:grid;position:relative;overflow:hidden}.stat-strip:before{content:"";background:linear-gradient(90deg, transparent 0%, var(--accent-primary) 30%, var(--progress-primary) 70%, transparent 100%);height:1px;position:absolute;top:0;left:0;right:0}.stat{background:var(--bg-card);border-right:1px solid var(--border-base);padding:18px 22px;transition:background .2s;position:relative;overflow:hidden}.stat:last-child{border-right:none}.stat:hover{background:var(--bg-elevated)}.stat:after{content:"";background:var(--accent-primary);opacity:0;height:2px;transition:opacity .2s;position:absolute;bottom:0;left:0;right:0}.stat:hover:after{opacity:.5}.stat-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.18em;text-transform:uppercase;margin-bottom:10px;font-size:9px}.stat-val{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-primary);font-size:34px;font-weight:900;line-height:1}.stat-val.green{color:var(--progress-primary)}.stat-val.purple{color:var(--accent-primary)}.stat-sub{font-family:var(--font-mono);color:var(--text-muted);margin-top:5px;font-size:10px}@media (width<=1000px){.stat-strip{grid-template-columns:repeat(2,1fr)}.stat{border-bottom:1px solid var(--border-base)}.stat:nth-child(odd){border-right:1px solid var(--border-base)}.stat:nth-child(2n){border-right:none}}@media (width<=768px){.stat-strip{grid-template-columns:1fr 1fr}}@media (width<=420px){.stat-strip{grid-template-columns:1fr 1fr}}.sec-hd{align-items:center;gap:12px;margin-bottom:16px;display:flex}.sec-ttl{font-family:var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--text-primary);white-space:nowrap;font-size:16px;font-weight:700}.sec-line{background:var(--border-base);flex:1;height:1px}.sec-cnt{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.1em;white-space:nowrap;font-size:10px}.sec-badge{font-family:var(--font-mono);border-radius:var(--radius-full);letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--border-base);color:var(--text-muted);white-space:nowrap;padding:3px 9px;font-size:9px}.game-card{background:var(--bg-card);border:1px solid var(--border-base);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .25s var(--ease-default), transform .25s var(--ease-default), box-shadow .25s var(--ease-default);flex-direction:column;height:100%;display:flex;position:relative;overflow:hidden;transform:translateY(0)}.game-card:hover{border-color:#7f5af059;transform:translateY(-4px);box-shadow:0 12px 32px #00000059}.game-card:before,.game-card:after{content:"";opacity:0;z-index:10;pointer-events:none;width:11px;height:11px;transition:opacity .25s;position:absolute}.game-card:before{border-top:2px solid var(--accent-primary);border-right:2px solid var(--accent-primary);border-radius:0 7px 0 0;top:-1px;right:-1px}.game-card:after{border-bottom:2px solid var(--progress-primary);border-left:2px solid var(--progress-primary);border-radius:0 0 0 7px;bottom:-1px;left:-1px}.game-card:hover:before,.game-card:hover:after{opacity:1}.gc-banner{align-items:flex-end;height:148px;padding:0 18px 16px;display:flex;position:relative;overflow:hidden}.gc-bg{transition:transform .5s var(--ease-default);background-position:50%;background-repeat:no-repeat;background-size:cover;position:absolute;inset:0}.gc-ov{background:linear-gradient(#16161a0d 0%,#16161a8c 45%,#16161afc 100%);position:absolute;inset:0}.gc-banner:after{content:"";pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#0000001a 3px 4px);position:absolute;inset:0}.gc-bc{z-index:3;width:100%;position:relative}.gc-banner-top{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.gc-icon-img{border-radius:var(--radius-md);object-fit:cover;border:1px solid #fff3;width:32px;height:32px}.gc-ttl{font-family:var(--font-display);letter-spacing:.05em;font-size:24px;font-weight:700;line-height:1.05;transition:color .2s}.gc-body{flex-direction:column;flex:1;padding:14px 18px 16px;display:flex}.gc-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.07em;margin-bottom:12px;font-size:10px}.gc-chips{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.gc-chip{font-family:var(--font-mono);border-radius:var(--radius-full);background:var(--surf-base);color:var(--text-muted);border:1px solid var(--border-base);letter-spacing:.05em;padding:3px 9px;font-size:10px}.gc-prog{opacity:1;height:34px;margin-bottom:14px}.gc-prog-bar{background:var(--surf-elevated);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.gc-prog-fill{background:var(--gradient-progress);height:100%;width:var(--p,0%);border-radius:2px;transition:width .6s cubic-bezier(.22,1,.36,1)}.gc-prog-lbl{font-family:var(--font-mono);color:var(--text-muted);opacity:1;font-size:10px}.gc-acts{gap:8px;margin-top:auto;display:flex}.btn-track{background:var(--accent-primary);color:#fffffe;border-radius:var(--radius-md);height:36px;font-family:var(--font-display);letter-spacing:.1em;text-transform:uppercase;border:1px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;font-size:13px;font-weight:700;transition:all .18s;display:flex;position:relative;overflow:hidden}.btn-track:before{content:"";background:linear-gradient(90deg,#0000,#ffffff1f,#0000);transition:transform .45s;position:absolute;inset:0;transform:translate(-100%)}.btn-track:hover:before{transform:translate(100%)}.btn-track:hover{background:var(--accent-hover);box-shadow:0 0 18px #7f5af066}.btn-track:active{transform:scale(.97)}.btn-track.tracked{color:var(--progress-primary);background:#2cb67d1f;border:1px solid #2cb67d59}.btn-track.tracked:hover{background:#2cb67d33;box-shadow:0 0 14px #2cb67d40}.lib-card{background:var(--bg-card);border:1px solid var(--border-base);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .2s var(--ease-default), top .2s var(--ease-default), box-shadow .2s var(--ease-default);position:relative;top:0;overflow:hidden}.lib-card:hover{border-color:#7f5af066;top:-2px;box-shadow:0 8px 24px #0000004d}.lib-card:before{content:"";border-top:2px solid var(--accent-primary);border-right:2px solid var(--accent-primary);opacity:0;border-radius:0 7px 0 0;width:11px;height:11px;transition:opacity .2s;position:absolute;top:-1px;right:-1px}.lib-card:hover:before{opacity:1}.lc-stripe{background:var(--gradient-progress);height:2px}.lc-body{padding:14px 16px 16px}.lc-top{align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.lc-icon-img{border-radius:var(--radius-lg);object-fit:cover;border:1px solid var(--border-base);flex-shrink:0;width:46px;height:46px}.lc-info{flex:1;min-width:0}.lc-nm{letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:14px;font-weight:700;line-height:1.2;overflow:hidden}.lc-sub{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;font-size:10px}.lc-pct{font-family:var(--font-display);letter-spacing:.04em;color:var(--progress-primary);flex-shrink:0;font-size:26px;font-weight:900;line-height:1}.lc-bar{background:var(--surf-elevated);border-radius:2px;height:6px;margin-bottom:6px;position:relative;overflow:hidden}.lc-bar-fill{background:var(--gradient-progress);height:100%;transition:width .8s var(--ease-default);border-radius:2px;position:relative}.lc-bar-fill:after{content:"";background:repeating-linear-gradient(90deg,#0000 0 16px,#00000040 16px 17px);position:absolute;inset:0}.lc-counts{font-family:var(--font-mono);color:var(--text-muted);justify-content:space-between;font-size:10px;display:flex}.lib-empty{border:1px dashed var(--border-base);border-radius:var(--radius-lg);text-align:center;grid-column:1/-1;justify-content:center;align-items:center;gap:14px;min-height:118px;padding:24px 22px;display:flex}.lib-empty-txt{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em;font-size:11px;line-height:1.7}.lib-empty-txt strong{color:var(--accent-primary);letter-spacing:.1em;margin-bottom:4px;font-size:13px;display:block}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-anim{background:linear-gradient(90deg, var(--bg-card) 25%, var(--surf-elevated) 50%, var(--bg-card) 75%);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.sk-lib-card{border:1px solid var(--border-base);border-radius:var(--radius-lg);height:120px;overflow:hidden}.sk-game-card{border:1px solid var(--border-base);border-radius:var(--radius-lg);height:330px;overflow:hidden}.toast{background:var(--bg-elevated);border:1px solid #7f5af066;border-left:3px solid var(--accent-primary);border-radius:var(--radius-md);font-family:var(--font-mono);letter-spacing:.06em;color:var(--text-primary);opacity:0;transition:all .25s var(--ease-default);z-index:999;pointer-events:none;padding:11px 18px;font-size:12px;position:fixed;bottom:22px;right:22px;transform:translateY(10px);box-shadow:0 8px 24px #0006}.toast.show{opacity:1;transform:translateY(0)}.catalog-page{flex-direction:column;gap:32px;display:flex}.catalog-hero{background:var(--bg-card);border:1px solid var(--border-base);border-radius:var(--radius-xl);justify-content:space-between;align-items:flex-end;gap:32px;padding:32px 28px 28px;display:flex;position:relative;overflow:hidden}.catalog-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#7f5af014 0%,#0000 70%);width:420px;height:420px;position:absolute;top:-40%;right:-10%}.catalog-hero:after{content:"";pointer-events:none;z-index:1;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#0000000a 3px 4px);position:absolute;inset:0}.catalog-hero-content{z-index:2;flex:1;position:relative}.catalog-hero-label{font-family:var(--font-mono);letter-spacing:.18em;color:var(--accent-primary);margin-bottom:8px;font-size:10px}.catalog-hero-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-primary);margin:0 0 10px;font-size:32px;font-weight:900;line-height:1.1}.catalog-hero-desc{font-family:var(--font-body);color:var(--text-muted);max-width:420px;margin:0;font-size:14px;line-height:1.5}.catalog-hero-stats{z-index:2;gap:24px;display:flex;position:relative}.catalog-stat{text-align:center;background:var(--bg-elevated);border:1px solid var(--border-base);border-radius:var(--radius-lg);min-width:90px;padding:12px 18px}.catalog-stat-val{font-family:var(--font-display);color:var(--text-primary);margin-bottom:4px;font-size:28px;font-weight:900;line-height:1}.catalog-stat-val.purple{color:var(--accent-primary)}.catalog-stat-label{font-family:var(--font-mono);letter-spacing:.12em;color:var(--text-muted);font-size:9px}@media (width<=768px){.catalog-hero{flex-direction:column;align-items:flex-start;gap:20px;padding:24px 20px}.catalog-hero-title{font-size:26px}.catalog-hero-stats{justify-content:space-between;width:100%}.catalog-stat{flex:1;min-width:0;padding:10px 12px}.catalog-stat-val{font-size:22px}}.game-page{flex-direction:column;display:flex}.gp-banner{aspect-ratio:16/9;border-bottom:1px solid var(--border-base);flex-shrink:0;align-items:flex-end;min-height:240px;max-height:300px;padding:32px 40px;display:flex;position:relative;overflow:hidden}.gp-banner-bg{object-fit:cover;object-position:center;width:100%;height:100%;transition:transform .6s var(--ease-default);position:absolute;inset:0}.gp-banner-ov{background:linear-gradient(#0f0f1326 0%,#0f0f1399 55%,#0f0f13f2 100%);position:absolute;inset:0}.gp-banner-grid{pointer-events:none;background-image:linear-gradient(#ffffff08 1px,#0000 1px),linear-gradient(90deg,#ffffff08 1px,#0000 1px);background-size:20px 20px;position:absolute;inset:0}.gp-banner:after{content:"";pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#00000014 3px 4px);position:absolute;inset:0}.gp-banner-content{z-index:3;align-items:flex-end;gap:16px;width:100%;display:flex;position:relative}.gp-icon{border-radius:var(--radius-xl);object-fit:cover;background:#ffffff1a;border:1px solid #fff3;flex-shrink:0;width:72px;height:72px;box-shadow:0 4px 20px #00000080}.gp-info{flex:1;min-width:0}.gp-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text-primary);text-shadow:0 4px 16px #000c;margin-bottom:8px;font-size:38px;font-weight:700;line-height:1.1}.gp-meta{font-family:var(--font-mono);color:#fff9;letter-spacing:.06em;gap:8px;font-size:13px;display:flex}.gp-meta span:not(:last-child):after{content:"·";color:#ffffff4d;margin-left:6px}.gp-stats-section{padding:20px 28px 0}.gp-progress-wrap{margin-bottom:10px}.gp-progress-bar{background:var(--surf-elevated);border-radius:3px;height:6px;overflow:hidden}.gp-progress-fill{background:var(--gradient-progress);height:100%;width:var(--gp-progress,0%);border-radius:3px;transition:width .6s cubic-bezier(.22,1,.36,1)}.gp-stats-row{gap:24px;display:flex}.gp-stat{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.01em;font-size:14px}.gp-stat strong{color:var(--text-primary);font-weight:500}.gp-banner-actions{flex-shrink:0;margin-bottom:6px}.gp-banner-actions .btn-track{min-width:160px;height:40px;padding:0 24px}@media (width<=768px){.gp-banner{height:180px;padding:20px}.gp-title{font-size:22px}.gp-icon{width:44px;height:44px}.gp-stats-section{padding:16px 20px 0}.gp-stats-row{flex-wrap:wrap;gap:16px}.gp-banner-content{flex-wrap:wrap}}.categories-section{padding:32px 28px 40px}.categories-header{border-bottom:1px solid var(--surf-elevated);justify-content:space-between;align-items:baseline;margin-bottom:20px;padding-bottom:12px;display:flex}.categories-title{font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em;font-size:24px;font-weight:700}.categories-count{font-family:var(--font-mono);color:var(--text-muted);font-size:13px}.categories-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.cat-card{background:var(--bg-card);border:1px solid var(--surf-elevated);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;gap:12px;padding:16px 20px;transition:all .2s;display:flex}.cat-card:hover{background:var(--surf-base);border-color:#ffffff1a;transform:translateY(-2px);box-shadow:0 8px 16px #0003}.cat-name{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:8px;font-size:18px;font-weight:600;display:flex}.cat-icon{font-size:20px}.cat-icon-img{object-fit:contain;filter:drop-shadow(0 2px 4px #00000080);width:32px;height:32px}.cat-progress{background:var(--surf-elevated);border-radius:3px;height:6px;overflow:hidden}.cat-fill{background:var(--gradient-progress);border-radius:3px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.cat-stats{font-family:var(--font-mono);color:var(--text-secondary);justify-content:space-between;font-size:13px;display:flex}@media (width<=768px){.categories-section{padding:24px 20px 32px}.categories-grid{grid-template-columns:1fr}}.checklist-page{flex-direction:row;align-items:flex-start;gap:16px;width:100%;padding:16px 24px 32px;display:flex}.cl-sidebar{background:var(--bg-card);border:1px solid var(--surf-elevated);border-radius:var(--radius-xl);flex-direction:column;flex-shrink:0;width:260px;padding:24px;display:flex}.cl-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.05em;margin-bottom:2px;font-size:18px;font-weight:700}.cl-sub{font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.15em;margin-bottom:20px;font-size:11px}.cl-pct{font-family:var(--font-display);color:var(--accent-primary);margin-bottom:8px;font-size:32px;font-weight:700;line-height:1}.cl-prog-track{background:var(--bg-base);border-radius:2px;height:4px;margin-bottom:8px;overflow:hidden}.cl-prog-fill{background:var(--gradient-progress);border-radius:2px;height:100%;transition:width .4s cubic-bezier(.22,1,.36,1)}.cl-prog-label{font-family:var(--font-mono);color:var(--text-muted);margin-bottom:24px;font-size:11px}.cl-filter-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:10px;font-size:10px}.cl-filter-btn{border-radius:var(--radius-lg);cursor:pointer;width:100%;font-family:var(--font-mono);background:0 0;border:none;justify-content:space-between;align-items:center;padding:8px 12px;transition:background .15s;display:flex}.cl-filter-btn:hover{background:#ffffff0a}.cl-filter-btn.active{background:var(--surf-elevated)}.cl-filter-btn .f-name{color:var(--text-secondary);font-size:12px}.cl-filter-btn .f-count{color:var(--text-muted);font-size:12px}.cl-filter-btn.active .f-name,.cl-filter-btn.active .f-count{color:var(--progress-primary);font-weight:700}.cl-main{background:var(--bg-card);border:1px solid var(--surf-elevated);border-radius:var(--radius-xl);flex-direction:column;flex:1;display:flex;overflow:hidden}.cl-topbar{background:var(--bg-elevated);border-bottom:1px solid var(--surf-elevated);flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 24px;display:flex}.cl-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.08em;text-transform:uppercase;font-size:16px;font-weight:600}.cl-hint{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:10px}.cl-list{flex:1;overflow-y:auto}.cl-item{border-bottom:1px solid #ffffff0a}.cl-item:last-child{border-bottom:none}.cl-item-row{cursor:pointer;align-items:center;gap:16px;padding:14px 24px;transition:background .1s;display:flex}.cl-item-row:hover,.cl-item-row.expanded{background:#ffffff05}.cl-checkbox{border-radius:var(--radius-md);border:1px solid var(--surf-elevated);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex;position:relative}.cl-checkbox:after{content:"";position:absolute;inset:-16px}.cl-checkbox.checked{background:var(--progress-primary);border:none}.cl-checkbox svg{display:none}.cl-checkbox.checked svg{display:block}.cl-item-body{flex:1;min-width:0}.cl-item-num{font-family:var(--font-mono);color:var(--text-muted);text-align:right;flex-shrink:0;align-self:center;min-width:28px;font-size:11px}.cl-item-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.03em;font-size:16px;transition:color .2s;display:inline}.cl-item-name.done{color:var(--text-muted)}.cl-item-desc{font-family:var(--font-mono);color:var(--text-secondary);margin-top:4px;font-size:12px;line-height:1.4;transition:color .2s}.cl-item-desc.done{color:var(--text-muted)}.cl-item-icon{object-fit:cover;filter:grayscale(80%)opacity(.55);border:1px solid #ffffff14;flex-shrink:0;width:62px;height:62px;transition:filter .3s,border-color .3s}.cl-item-icon--circle{border-radius:var(--radius-full)}.cl-item-icon--square{border-radius:var(--radius-md)}.cl-item-icon.done{filter:grayscale(0%)opacity();border-color:#fff3}.cl-item-right{flex-shrink:0;align-items:center;gap:12px;display:flex}.cl-missable-dot{border-radius:var(--radius-full);background:var(--warning-primary);width:6px;height:6px;box-shadow:0 0 5px var(--warning-muted)}.cl-arrow-btn{opacity:.35;justify-content:center;align-items:center;width:24px;height:24px;transition:opacity .15s;display:flex}.cl-item-row:hover .cl-arrow-btn{opacity:1}.cl-arrow-btn svg{transition:transform .2s}.cl-arrow-btn.open svg{transform:rotate(180deg)}.cl-no-arrow{width:24px}.cl-acc-body{opacity:0;grid-template-rows:0fr;transition:grid-template-rows .4s cubic-bezier(.22,1,.36,1),opacity .3s ease-in-out;display:grid}.cl-acc-body.open{opacity:1;grid-template-rows:1fr}.cl-acc-wrapper{overflow:hidden}.cl-acc-inner{flex-direction:column;gap:12px;padding:16px 24px 20px 60px;display:flex}.cl-hint-text{font-family:var(--font-mono);color:var(--text-secondary);white-space:pre-wrap;font-size:12px;line-height:1.7}.cl-sec-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;margin-bottom:6px;font-size:9px}.cl-code-block{background:var(--bg-base);border:1px solid var(--surf-elevated);border-radius:var(--radius-lg);padding:10px 14px;position:relative}.cl-code-text{font-family:var(--font-mono);color:#ccc;white-space:pre-line;font-size:11px;line-height:1.8;transition:filter .2s}.hint-text{color:var(--text-secondary);white-space:pre-wrap;margin:0 0 8px;font-size:14px;line-height:1.6}.hint-list{color:var(--text-secondary);margin:0 0 8px;padding-left:20px;font-size:14px;line-height:1.6}.hint-list-item{margin-bottom:4px}.hint-image{border-radius:var(--radius-md);object-fit:cover;cursor:pointer;width:100%;max-width:760px;max-height:480px;margin:8px 0;display:block}.hint-figure{flex-direction:column;gap:4px;max-width:760px;margin:8px 0;display:flex}.hint-figure .hint-image{margin:0}.hint-figcaption{color:var(--text-secondary);line-height:1.4}.hint-image-grid{gap:8px;display:grid}.hint-image-grid--single{grid-template-columns:1fr}.hint-image-grid--multi{grid-template-columns:1fr 1fr}.hint-image-grid .hint-figure{max-width:100%;margin:0}.hint-image-grid--multi>:last-child:nth-child(odd){grid-column:1/-1;justify-self:center;width:calc(50% - 4px)}#lightbox{z-index:1000;cursor:zoom-out;background:#000000e0;justify-content:center;align-items:center;display:none;position:fixed;inset:0}#lightbox.open{display:flex}#lightbox-img{border-radius:var(--radius-lg);object-fit:contain;max-width:90vw;max-height:90vh}.hint-link{border:1px solid var(--accent-hover);color:var(--accent-hover);font-family:var(--font-mono);border-radius:var(--radius-sm);opacity:.85;background:0 0;align-self:flex-start;margin-top:12px;padding:6px 12px;font-size:16px;text-decoration:none;transition:color .15s,border-color .15s,opacity .15s;display:inline-block}.hint-link:hover{opacity:1}.hint-spoiler-body{margin-top:8px;display:none}.hint-spoiler.is-open>.hint-spoiler-body{display:block}.hint-spoiler-btn{border:1px solid var(--surf-elevated);color:var(--text-muted);font-family:var(--font-mono);border-radius:var(--radius-sm);cursor:pointer;background:0 0;margin-bottom:12px;padding:6px 12px;font-size:16px;transition:color .15s,border-color .15s}.hint-spoiler-btn:hover{color:var(--text-primary);border-color:var(--text-muted)}@media (width<=768px){.checklist-page{flex-direction:column;padding:16px}.cl-sidebar{width:100%}}.cl-item.is-highlighted{box-shadow:0 0 0 2px var(--accent-hover), 0 0 24px #7f5af059;border-radius:var(--radius-md);animation:2s ease-out cl-highlight-pulse}@keyframes cl-highlight-pulse{0%{box-shadow:0 0 0 0 var(--accent-hover), 0 0 0 #7f5af000}20%{box-shadow:0 0 0 2px var(--accent-hover), 0 0 28px #7f5af073}to{box-shadow:0 0 #0000,0 0 #7f5af000}}@media (prefers-reduced-motion:reduce){.cl-item.is-highlighted{animation:none}}.cat-card--guide{min-height:0}.cat-card--guide:hover{border-color:#7f5af066}.guides-page{padding:24px 28px 40px}.guides-header{border-bottom:1px solid var(--surf-elevated);justify-content:space-between;align-items:baseline;margin-bottom:20px;padding-bottom:12px;display:flex}.guides-title{font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase;letter-spacing:.04em;font-size:24px;font-weight:700}.guides-sub{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;font-size:11px}.guides-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.guide-card{background:var(--bg-card);border:1px solid var(--surf-elevated);border-radius:var(--radius-lg);cursor:pointer;align-items:center;gap:12px;min-height:72px;padding:18px 20px;transition:background .2s,border-color .2s,transform .2s;display:flex}.guide-card:hover{background:var(--surf-base);border-color:#7f5af066;transform:translateY(-2px)}.guide-card-icon{object-fit:contain;flex-shrink:0;width:32px;height:32px}.guide-card-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.03em;font-size:16px;font-weight:600;line-height:1.3}.guide-page{max-width:1200px;margin:0 auto;padding:32px 40px 64px}.guide-page-header{border-bottom:1px solid var(--surf-elevated);margin-bottom:24px;padding-bottom:16px}.guide-page-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.03em;margin:0 0 8px;font-size:28px;font-weight:700;line-height:1.2}.guide-page-meta{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;font-size:12px}.guide-page-body{flex-direction:column;gap:16px;display:flex}.guide-page-body .hint-text,.guide-page-body .hint-list,.guide-page-body .hint-figcaption{font-size:18px;line-height:1.6}.guide-page-empty{font-family:var(--font-mono);color:var(--text-muted);text-align:center;padding:32px 0;font-size:13px}@media (width<=768px){.guides-page{padding:16px}.guides-grid{grid-template-columns:1fr}.guide-page{padding:20px 16px 48px}.guide-page-title{font-size:22px}}.fm-overlay{z-index:300;opacity:0;pointer-events:none;background:#0f0f13cc;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:fixed;inset:0}.fm-overlay--open{opacity:1;pointer-events:all}.fm-modal{background:var(--bg-card);border:1px solid var(--surf-elevated);border-radius:var(--radius-xl);width:100%;max-width:440px;max-height:calc(100vh - 32px);padding:24px;transition:transform .15s;overflow-y:auto;transform:translateY(8px)}.fm-overlay--open .fm-modal{transform:translateY(0)}.fm-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.fm-title{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase;font-size:18px;font-weight:700}.fm-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1;transition:color .12s}.fm-close:hover{color:var(--text-primary)}.fm-subtitle{color:var(--text-secondary);margin:0 0 16px;font-size:14px}.fm-chips{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.fm-chip{font-family:var(--font-body);border-radius:var(--radius-full);border:1px solid var(--surf-elevated);background:var(--surf-base);color:var(--text-secondary);cursor:pointer;padding:5px 12px;font-size:14px;transition:border-color .12s,background .12s,color .12s}.fm-chip:hover{border-color:var(--accent-primary);color:var(--text-primary)}.fm-chip--active{border-color:var(--accent-primary);color:var(--accent-hover);background:#7f5af01f}.fm-field{margin-bottom:12px}.fm-field--hidden{display:none}.fm-label{font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:5px;font-size:11px;display:block}.fm-input,.fm-textarea{background:var(--surf-base);border:1px solid var(--surf-elevated);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);resize:none;box-sizing:border-box;outline:none;padding:8px 12px;font-size:14px;transition:border-color .12s}.fm-input:focus,.fm-textarea:focus{border-color:var(--accent-primary)}.fm-input.fm-input--error,.fm-textarea.fm-input--error{border-color:var(--danger-primary)}.fm-textarea{min-height:96px;line-height:1.5}.fm-submit{width:100%;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;background:var(--accent-primary);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;border:none;margin-top:4px;padding:10px;font-size:14px;font-weight:700;transition:background .12s,opacity .12s}.fm-submit:hover{background:var(--accent-hover)}.fm-submit:disabled{opacity:.5;cursor:not-allowed}@media (width<=768px){.fm-overlay{padding:12px}.fm-modal{max-width:100%;padding:20px}}
