:root{--bg:#0f1020;--surface:#1a1b2e;--surface2:#23243d;--line:#2e2f4a;--text:#e9e9f4;--muted:#9a9ab8;--accent:#7c3aed;--accent2:#06b6d4;--radius:14px}
*{box-sizing:border-box}html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}
a{color:inherit;text-decoration:none}
main{max-width:1180px;margin:0 auto;padding:18px 16px 48px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}
/* header */
.site-head{position:sticky;top:0;z-index:50;display:flex;gap:16px;align-items:center;padding:12px 16px;background:rgba(15,16,32,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{font-weight:800;font-size:20px;letter-spacing:-.02em;white-space:nowrap}
.brand span{color:var(--accent2)}.brand-mark{color:var(--accent)}
.head-nav{margin-left:auto;display:flex;gap:18px;font-weight:600;color:var(--muted)}
.head-nav a:hover{color:var(--text)}
.search-wrap{position:relative;flex:1;max-width:420px}
#q{width:100%;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:15px}
#q:focus{outline:none;border-color:var(--accent)}
.results{position:absolute;top:46px;left:0;right:0;background:var(--surface2);border:1px solid var(--line);border-radius:12px;overflow:hidden;max-height:60vh;overflow-y:auto;box-shadow:0 18px 40px rgba(0,0,0,.5)}
.results a{display:flex;gap:10px;align-items:center;padding:9px 12px;border-bottom:1px solid var(--line);font-size:14px}
.results a:hover,.results a.sel{background:var(--accent)}
.results .rc{margin-left:auto;color:var(--muted);font-size:12px}
/* hero */
.hero{padding:30px 22px;margin-bottom:20px;border-radius:var(--radius);background:linear-gradient(135deg,#241b4d,#11213f 60%,#0d2b34);border:1px solid var(--line)}
.hero h1{margin:0 0 6px;font-size:32px;letter-spacing:-.02em}
.hero p{margin:0;color:var(--muted);font-size:17px}
.hero.compact{padding:20px 22px}.hero.compact h1{font-size:24px}
.btn-rnd{margin-top:16px;background:var(--accent);color:#fff;border:0;border-radius:10px;padding:11px 20px;font-weight:700;font-size:15px;cursor:pointer}
.btn-rnd:hover{background:#6d28d9}
.js-random{cursor:pointer}
.section-title{font-size:20px;margin:30px 4px 12px}
/* grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .12s,border-color .12s}
.card:hover{transform:translateY(-3px);border-color:var(--accent)}
.thumb{display:block;aspect-ratio:4/3;background:var(--surface2);overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card-t{padding:8px 10px 2px;font-weight:700;font-size:14px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-c{padding:0 10px 10px;color:var(--muted);font-size:12px}
.cat-row{margin:26px 0}
.row-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 4px 10px}
.row-head h2{font-size:19px;margin:0}
.more{color:var(--accent2);font-weight:600;font-size:14px}
.coll-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:8px}
.coll-card{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:14px;border:1px solid var(--line);background-size:cover;background-position:center;background-image:linear-gradient(transparent,rgba(12,13,28,.55),rgba(12,13,28,.94)),var(--bg)}
.coll-card:hover{border-color:var(--accent)}
.coll-t{font-weight:800;font-size:16px;line-height:1.2}
.coll-n{color:#c9c9de;font-size:12px;margin-top:3px}
/* game */
.crumbs{color:var(--muted);font-size:13px;margin:4px 4px 14px}.crumbs a:hover{color:var(--text)}
.game h1{font-size:24px;margin:0 0 14px}
.stage-wrap{background:#000;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.stage{position:relative;width:100%;height:0}
.stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0;opacity:0;transition:opacity .35s}
.stage iframe.loaded{opacity:1}
.stage-load{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--muted);font-size:14px}
.spin{width:18px;height:18px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.stage-bar{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);flex-wrap:wrap}
.cat-pill{background:var(--accent);color:#fff;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px}
.stage-bar button{background:var(--surface2);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:7px 12px;font-weight:600;font-size:13px;cursor:pointer}
.stage-bar button:hover{border-color:var(--accent)}
#fav{margin-left:auto}
#fav.on{color:#ff6b9d;border-color:#ff6b9d}
.game-meta{margin:18px 2px;color:#cfd0e4}.game-meta p{margin:0 0 12px}
.instr h3{font-size:16px;margin:14px 0 6px}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.tag{background:var(--surface2);border:1px solid var(--line);color:var(--muted);font-size:12px;padding:4px 10px;border-radius:999px}
.tag:hover{color:var(--text);border-color:var(--accent)}
/* prose */
.prose{max-width:740px}.prose h2{font-size:18px;margin:22px 0 6px}.prose p{color:#cfd0e4}
.prose a{color:var(--accent2)}
.byline{color:var(--muted);font-size:13px;margin:-6px 0 18px}
.guide h2{font-size:19px;margin:24px 0 8px}
.guide ul{padding-left:20px}.guide li{margin:7px 0}
.guide .grid{margin-top:8px}
.faqs{margin-top:26px;border-top:1px solid var(--line);padding-top:18px}
.faq-q h3{font-size:16px;margin:16px 0 4px}.faq-q p{color:#cfd0e4;margin:0}
.guides-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.guide-card{padding:16px 16px 18px;min-height:120px}
.guide-card .card-t{font-size:15px;padding:0 0 7px}
.guide-card .card-c{padding:0;-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}
/* footer */
.site-foot{border-top:1px solid var(--line);margin-top:40px;padding:30px 16px}
.foot-cols{max-width:1180px;margin:0 auto;display:flex;flex-wrap:wrap;gap:34px}
.foot-cols h4{margin:0 0 8px;font-size:14px}
.foot-cols a{display:block;color:var(--muted);font-size:14px;padding:2px 0}.foot-cols a:hover{color:var(--text)}
.foot-cols>div:first-child{max-width:280px}
.muted{color:var(--muted)}.small{font-size:12px;max-width:1180px;margin:22px auto 0}
@media(max-width:620px){.head-nav{display:none}.hero h1{font-size:26px}}
