:root {
  --pixel-bg: #f1edff;
  --pixel-paper: #fffaff;
  --pixel-ink: #251f35;
  --pixel-muted: #665f7a;
  --pixel-blue: #6a45d8;
  --pixel-green: #18b888;
  --pixel-yellow: #ffc857;
  --pixel-orange: #ff7a3d;
  --pixel-pink: #f35ba5;
  --pixel-line: #251f35;
  --pixel-shadow: #3a275c;
}

* {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  min-width: 320px;
  margin: 0;
  overflow-x: hidden;
  background:
    linear-gradient(90deg, rgba(70, 49, 128, .06) 1px, transparent 1px) 0 0 / 22px 22px,
    linear-gradient(rgba(70, 49, 128, .06) 1px, transparent 1px) 0 0 / 22px 22px,
    linear-gradient(135deg, rgba(255, 122, 61, .10), rgba(106, 69, 216, .08)),
    var(--pixel-bg);
  color: var(--pixel-ink);
  font-family: "Arial", "Microsoft YaHei", "PingFang SC", sans-serif;
  line-height: 1.55;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover,
a:focus {
  color: var(--pixel-blue);
}

img {
  display: block;
  max-width: 100%;
}

svg {
  width: 1.1em;
  height: 1.1em;
  stroke-width: 2.4;
}

.topbar {
  background: var(--pixel-orange);
  border-bottom: 4px solid var(--pixel-line);
}

.topbar-links a {
  color: var(--pixel-ink);
}

.brand-zone {
  background: linear-gradient(180deg, #fffaff, #f8f1ff);
}

.brand {
  min-width: 0;
}

.brand-mark {
  min-width: 64px;
  padding: .75rem !important;
  color: #fff;
  background-color: var(--pixel-blue) !important;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.brand-copy strong {
  display: block;
  font-size: clamp(1.8rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: 0;
}

.brand-copy small {
  display: block;
  margin-top: .35rem;
  color: var(--pixel-muted);
  font-weight: 700;
}

.chip {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: .35rem .75rem;
  border: 2px solid var(--pixel-line);
  background: #fff7f1;
  color: var(--pixel-ink);
  font-weight: 700;
  box-shadow: 3px 3px 0 var(--pixel-shadow);
}

.pixel-nav {
  background: var(--pixel-blue);
  border-top: 4px solid var(--pixel-line);
  border-bottom: 4px solid var(--pixel-line);
}

.pixel-nav .nav-link {
  min-height: 52px;
  display: grid;
  place-items: center;
  color: #fff;
  font-weight: 800;
}

.pixel-nav .nav-link.active,
.pixel-nav .nav-link:hover,
.pixel-nav .nav-link:focus {
  color: var(--pixel-ink);
  background: var(--pixel-orange);
}

.nes-btn.is-primary {
  background-color: var(--pixel-blue);
}

.nes-btn.is-success {
  background-color: var(--pixel-green);
}

.nes-btn.is-warning {
  background-color: var(--pixel-orange);
}

.nes-btn.is-error {
  background-color: var(--pixel-pink);
}

.navbar-toggler {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 42px;
}

.page {
  padding-bottom: 1rem;
}

.nes-container {
  background-color: var(--pixel-paper);
}

.nes-container > .row {
  margin: 0;
}

.section-title h2,
.footer-heading {
  margin: 0;
  font-size: clamp(1.15rem, 2.4vw, 1.55rem);
  font-weight: 900;
  line-height: 1.25;
}

.more-link {
  flex: 0 0 auto;
  color: var(--pixel-muted);
  font-weight: 800;
}

.vertical-title {
  min-height: 128px;
  border: 4px solid var(--pixel-line);
  background: var(--pixel-blue);
  color: #fff;
  font-size: 1.25rem;
  font-weight: 900;
  text-align: center;
  box-shadow: 5px 5px 0 var(--pixel-orange);
}

.vertical-title span {
  writing-mode: vertical-rl;
  letter-spacing: 0;
}

.hot-icon-grid {
  display: grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 1rem;
}

.hot-icon-grid a,
.category-strip a {
  min-width: 0;
  color: var(--pixel-ink);
  text-align: center;
}

.hot-icon-grid img {
  width: 64px;
  height: 64px;
  margin: 0 auto .55rem;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
  image-rendering: auto;
}

.hot-icon-grid span,
.category-strip span {
  display: block;
  min-width: 0;
  overflow: hidden;
  color: var(--pixel-muted);
  font-size: .9rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hot-fill {
  display: block;
}

.tag-cloud {
  min-width: 0;
}

.tag-cloud p {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: .55rem .8rem;
  overflow: hidden;
  white-space: nowrap;
}

.tag-cloud b {
  display: inline-flex;
  flex: 0 0 auto;
  min-width: 54px;
  justify-content: center;
  padding: .2rem .65rem;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-blue);
  color: #fff;
}

.tag-cloud a {
  min-width: 0;
  overflow: hidden;
  color: var(--pixel-muted);
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.first-screen .nes-container,
.focus-swiper,
.focus-slide {
  min-height: 100%;
}

.focus-swiper {
  overflow: hidden;
}

.focus-slide {
  position: relative;
  min-height: 430px;
  overflow: hidden;
  background: #000;
}

.focus-slide img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  object-fit: cover;
}

.focus-caption {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  color: #fff;
  background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .86));
}

.focus-caption h1,
.focus-caption h2 {
  max-width: 13em;
  margin: .8rem 0 .45rem;
  font-size: clamp(1.35rem, 3vw, 2.15rem);
  font-weight: 900;
  line-height: 1.18;
}

.focus-caption p {
  max-width: 30em;
  margin: 0;
  color: rgba(255, 255, 255, .88);
  font-weight: 700;
}

.focus-dots {
  bottom: .65rem !important;
}

.swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  border: 2px solid #fff;
  border-radius: 0;
  background: var(--pixel-orange);
  opacity: 1;
}

.swiper-pagination-bullet-active {
  background: var(--pixel-yellow);
}

.section-kicker {
  display: inline-flex;
  margin-bottom: .55rem;
  padding: .18rem .55rem;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-orange);
  font-weight: 900;
}

.top-story {
  border: 3px solid var(--pixel-line);
  background: #fff;
}

.top-story strong,
.top-story small {
  display: block;
}

.top-story strong {
  margin-bottom: .5rem;
  font-size: 1.05rem;
  line-height: 1.45;
}

.top-story small {
  color: var(--pixel-muted);
  font-weight: 700;
}

.update-list li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
  min-height: 38px;
  border-bottom: 2px dashed rgba(70, 49, 128, .24);
}

.update-list span {
  color: var(--pixel-blue);
  font-weight: 900;
}

.update-list a,
.side-rank-list a,
.rank-board a {
  min-width: 0;
  overflow: hidden;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.update-list time,
.side-rank-list span,
.rank-board span {
  color: var(--pixel-muted);
  font-size: .9rem;
  font-weight: 800;
}

.side-rank-list {
  counter-reset: rank;
}

.side-rank-list li {
  counter-increment: rank;
  display: grid;
  grid-template-columns: auto 42px minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
  padding: .5rem 0;
  border-bottom: 2px dashed rgba(70, 49, 128, .22);
}

.side-rank-list li::before {
  content: counter(rank);
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-orange);
  font-size: .85rem;
  font-weight: 900;
}

.side-rank-list img {
  width: 42px;
  height: 42px;
  border: 2px solid var(--pixel-line);
  object-fit: cover;
}

.category-strip a {
  text-align: left;
}

.category-strip svg {
  color: var(--pixel-orange);
}

.category-strip b {
  display: block;
  margin: .45rem 0 .25rem;
  font-size: 1rem;
}

.pixel-tabs {
  gap: .5rem;
}

.pixel-tabs .nav-link {
  border: 3px solid var(--pixel-line);
  border-radius: 0;
  background: #fff;
  color: var(--pixel-ink);
  font-weight: 900;
  box-shadow: 3px 3px 0 var(--pixel-shadow);
}

.pixel-tabs .nav-link.active {
  background: var(--pixel-orange);
  color: var(--pixel-ink);
}

.resource-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
  border: 3px solid var(--pixel-line);
  background: #fff;
  min-width: 0;
}

.resource-card img {
  width: 76px;
  height: 76px;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.resource-card div {
  min-width: 0;
}

.resource-card h3 {
  margin: 0 0 .35rem;
  overflow: hidden;
  font-size: 1.05rem;
  font-weight: 900;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.resource-card p {
  display: -webkit-box;
  margin: 0 0 .35rem;
  overflow: hidden;
  color: var(--pixel-muted);
  font-size: .92rem;
  font-weight: 700;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.resource-card span {
  color: var(--pixel-blue);
  font-size: .9rem;
  font-weight: 900;
}

.resource-card .nes-btn {
  min-width: 70px;
  padding-right: .65rem;
  padding-left: .65rem;
  text-align: center;
}

.feature-news,
.news-card,
.topic-card {
  border: 3px solid var(--pixel-line);
  background: #fff;
  color: var(--pixel-ink);
}

.feature-news img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border: 3px solid var(--pixel-line);
}

.feature-news h3 {
  margin: 0 0 .55rem;
  font-size: 1.2rem;
  font-weight: 900;
  line-height: 1.35;
}

.feature-news p {
  margin: 0;
  color: var(--pixel-muted);
  font-weight: 700;
}

.news-card {
  display: grid;
  min-height: 104px;
  gap: .35rem;
}

.news-card span {
  color: var(--pixel-blue);
  font-weight: 900;
}

.news-card strong {
  display: -webkit-box;
  overflow: hidden;
  line-height: 1.45;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.news-card time {
  color: var(--pixel-muted);
  font-weight: 800;
}

.rank-board {
  border: 3px solid var(--pixel-line);
  background: #fff;
}

.rank-board h3 {
  margin: 0 0 .75rem;
  font-size: 1.05rem;
  font-weight: 900;
}

.rank-board ol {
  display: grid;
  gap: .5rem;
  margin: 0;
  padding: 0;
  counter-reset: board-rank;
  list-style: none;
}

.rank-board li {
  counter-increment: board-rank;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .65rem;
  align-items: center;
  min-width: 0;
}

.rank-board li::before {
  content: counter(board-rank);
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-orange);
  color: #fff;
  font-size: .85rem;
  font-weight: 900;
}

.topic-stack {
  display: grid;
  gap: 1rem;
}

.topic-card {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
}

.topic-card img {
  width: 150px;
  aspect-ratio: 4 / 3;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.topic-card div {
  min-width: 0;
}

.topic-card span {
  color: var(--pixel-blue);
  font-weight: 900;
}

.topic-card h3 {
  margin: .4rem 0;
  font-size: 1.08rem;
  font-weight: 900;
  line-height: 1.35;
}

.topic-card p {
  display: -webkit-box;
  margin: 0;
  overflow: hidden;
  color: var(--pixel-muted);
  font-weight: 700;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.friend-links .chip {
  background: #fff7f1;
}

.site-footer {
  border-top: 4px solid var(--pixel-line);
  background: #241736;
  color: #fff;
}

.site-footer a {
  color: #fff;
}

.site-footer p,
.copyright {
  color: rgba(255, 255, 255, .72);
  font-weight: 700;
}

.footer-brand .brand-mark {
  background-color: var(--pixel-pink) !important;
}

.footer-list {
  display: grid;
  gap: .45rem;
}

.footer-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .45rem .9rem;
}

.copyright {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: .75rem;
  border-top: 2px dashed rgba(255, 255, 255, .28);
}

.breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: 0;
  color: var(--pixel-muted);
  font-weight: 800;
}

.breadcrumb a::after {
  content: "/";
  margin-left: .5rem;
  color: var(--pixel-line);
}

.page-title h1,
.list-head h1,
.detail-hero h1,
.rank-page-head h1,
.topic-detail-head h1,
.article-head h1,
.about-head h1,
.sitemap-head h1 {
  margin: 0;
  font-size: clamp(1.45rem, 3vw, 2.15rem);
  font-weight: 900;
  line-height: 1.25;
}

.page-title p,
.list-head p,
.article-head p,
.about-head p,
.sitemap-head p {
  margin: .6rem 0 0;
  color: var(--pixel-muted);
  font-weight: 700;
}

.category-panel,
.resource-panel,
.detail-panel,
.article-panel,
.rank-page-panel,
.topic-panel,
.utility-panel {
  border: 3px solid var(--pixel-line);
  background: #fff;
}

.category-panel {
  display: grid;
  gap: .85rem;
}

.category-row {
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr);
  gap: .75rem;
  align-items: start;
}

.category-row strong {
  display: inline-flex;
  justify-content: center;
  padding: .35rem .6rem;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-blue);
  color: #fff;
  font-weight: 900;
}

.category-row div {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem .9rem;
  min-width: 0;
}

.category-row a,
.filter-tabs a,
.about-links a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: .25rem .65rem;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-paper);
  color: var(--pixel-ink);
  font-weight: 800;
}

.category-row a.active,
.filter-tabs a.active,
.about-links a.active {
  background: var(--pixel-orange);
}

.resource-list,
.article-list,
.rank-main-list,
.included-list,
.collection-list,
.sitemap-list {
  display: grid;
  gap: 1rem;
}

.resource-row,
.article-row,
.rank-main-list li,
.included-item,
.collection-row,
.sitemap-module {
  border: 3px solid var(--pixel-line);
  background: #fff;
}

.resource-row,
.included-item {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}

.resource-row img,
.included-item > img {
  width: 82px;
  height: 82px;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.resource-row h2,
.resource-row h3,
.included-item h2,
.included-item h3,
.collection-row h2,
.article-row h2 {
  margin: 0 0 .45rem;
  font-size: 1.08rem;
  font-weight: 900;
  line-height: 1.35;
}

.resource-row p,
.included-item p,
.collection-row p,
.article-row p,
.rank-main-info p {
  margin: 0 0 .45rem;
  color: var(--pixel-muted);
  font-weight: 700;
}

.meta-line,
.resource-meta,
.article-meta,
.collection-meta,
.rank-main-info div,
.detail-meta-tags,
.topic-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem .7rem;
  color: var(--pixel-blue);
  font-size: .92rem;
  font-weight: 900;
}

.resource-action,
.topic-download,
.rank-main-action,
.collection-action {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 38px;
  padding: .35rem .75rem;
  border: 3px solid var(--pixel-line);
  background: var(--pixel-orange);
  color: var(--pixel-ink);
  font-weight: 900;
  box-shadow: 3px 3px 0 var(--pixel-shadow);
}

.resource-action.is-disabled,
.topic-download.is-disabled,
.rank-main-action.is-disabled {
  background: #d9d9d9;
  color: var(--pixel-muted);
  cursor: not-allowed;
}

.pager {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: center;
  margin-top: 1.25rem;
}

.pager a,
.pager span {
  display: inline-flex;
  min-width: 38px;
  min-height: 36px;
  justify-content: center;
  align-items: center;
  padding: .25rem .6rem;
  border: 2px solid var(--pixel-line);
  background: #fff;
  font-weight: 900;
}

.pager .active {
  background: var(--pixel-orange);
}

.pager .disabled {
  color: var(--pixel-muted);
  background: #eee;
}

.detail-hero {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
}

.detail-hero img {
  width: 104px;
  height: 104px;
  border: 4px solid var(--pixel-line);
  object-fit: cover;
}

.info-matrix {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
}

.info-matrix div,
.apk-grid div,
.topic-info-grid div {
  min-width: 0;
  padding: .75rem;
  border: 2px solid var(--pixel-line);
  background: var(--pixel-paper);
}

.info-matrix dt,
.apk-grid dt,
.topic-info-grid dt {
  color: var(--pixel-muted);
  font-size: .82rem;
  font-weight: 800;
}

.info-matrix dd,
.apk-grid dd,
.topic-info-grid dd {
  margin: .2rem 0 0;
  font-weight: 900;
}

.download-state-grid {
  display: grid;
  gap: .75rem;
}

.download-state {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .45rem;
  min-height: 48px;
  padding: .55rem .75rem;
  border: 3px solid var(--pixel-line);
  background: var(--pixel-green);
  color: #fff;
  font-weight: 900;
  box-shadow: 4px 4px 0 var(--pixel-shadow);
}

.download-state.is-ios {
  background: var(--pixel-blue);
}

.download-state.is-disabled {
  background: #d8d8d8;
  color: var(--pixel-muted);
  box-shadow: none;
  cursor: not-allowed;
}

.shot-swiper {
  overflow: hidden;
}

.shot-card {
  border: 3px solid var(--pixel-line);
  background: #fff;
}

.shot-card img {
  width: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
}

.rich-text {
  color: var(--pixel-ink);
  font-weight: 700;
}

.rich-text p,
.rich-text li {
  margin-bottom: .8rem;
}

.software-detail-content img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 1rem auto;
}

/* Super mushroom icon by Lorc, CC BY 3.0, from Game-icons.net */
.software-detail-content h3 {
  position: relative;
  width: fit-content;
  max-width: 100%;
  margin: 1.4rem 0 .85rem;
  padding: .42rem .72rem .42rem 2.15rem;
  border: 3px solid var(--pixel-line);
  background: #fff;
  color: var(--pixel-ink);
  font-size: 1.12rem;
  line-height: 1.65;
  font-weight: 900;
  box-shadow: 4px 4px 0 var(--pixel-orange);
}

.software-detail-content h3::before {
  content: "";
  position: absolute;
  left: .52rem;
  top: 50%;
  width: 1.08rem;
  height: 1.08rem;
  background: url("../image/super-mushroom.svg") center / contain no-repeat;
  image-rendering: pixelated;
  filter: drop-shadow(2px 2px 0 var(--pixel-line));
  transform: translateY(-50%);
}

.apk-grid,
.topic-info-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}

.permission-list {
  display: grid;
  gap: .85rem;
}

.permission-list li {
  padding-bottom: .85rem;
  border-bottom: 2px dashed rgba(70, 49, 128, .24);
}

.permission-list strong,
.permission-list span {
  display: block;
}

.permission-list span {
  margin-top: .25rem;
  color: var(--pixel-muted);
  font-weight: 700;
}

.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.article-row {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 1rem;
}

.article-row img {
  width: 100%;
  height: 124px;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.article-head .article-meta {
  margin-top: .75rem;
}

.article-side-list {
  display: grid;
  gap: .75rem;
}

.article-side-list a {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: .75rem;
  align-items: center;
  border: 2px solid var(--pixel-line);
  background: #fff;
  color: var(--pixel-ink);
}

.article-side-list img {
  width: 70px;
  height: 58px;
  object-fit: cover;
}

.rank-page-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
}

.rank-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.rank-tabs a {
  padding: .25rem .65rem;
  border: 2px solid var(--pixel-line);
  background: #fff;
  font-weight: 900;
}

.rank-tabs a.active {
  background: var(--pixel-orange);
}

.rank-main-list {
  margin: 0;
  padding: 0;
  counter-reset: page-rank;
  list-style: none;
}

.rank-main-list li {
  counter-increment: page-rank;
  display: grid;
  grid-template-columns: 44px 76px minmax(0, 1fr) auto auto;
  gap: .85rem;
  align-items: center;
}

.rank-main-list li::before {
  content: counter(page-rank, decimal-leading-zero);
  display: grid;
  width: 44px;
  height: 44px;
  place-items: center;
  border: 3px solid var(--pixel-line);
  background: var(--pixel-orange);
  color: #fff;
  font-weight: 900;
}

.rank-main-list img {
  width: 76px;
  height: 76px;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.rank-main-info {
  min-width: 0;
}

.rank-main-info a {
  display: inline-block;
  margin-bottom: .35rem;
  font-size: 1.06rem;
  font-weight: 900;
}

.rank-main-stat {
  text-align: right;
}

.rank-main-stat span,
.rank-main-stat strong {
  display: block;
}

.rank-main-stat span {
  color: var(--pixel-muted);
  font-size: .82rem;
  font-weight: 800;
}

.rank-main-stat strong {
  color: var(--pixel-blue);
  font-size: 1.1rem;
  font-weight: 900;
}

.collection-row {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: center;
}

.collection-row > img {
  width: 100%;
  aspect-ratio: 4 / 3;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.collection-icons,
.included-icons {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: .55rem;
}

.collection-icons img,
.included-icons img {
  width: 42px;
  height: 42px;
  border: 2px solid var(--pixel-line);
  object-fit: cover;
}

.topic-detail-head {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1.25rem;
  align-items: center;
  text-align: left;
}

.topic-detail-head > img {
  width: 100%;
  aspect-ratio: 16 / 10;
  border: 3px solid var(--pixel-line);
  object-fit: cover;
}

.sitemap-module h2 {
  margin: 0 0 .75rem;
  font-size: 1.25rem;
  font-weight: 900;
}

.sitemap-module div {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem .8rem;
}

.sitemap-module a {
  color: var(--pixel-muted);
  font-weight: 800;
}

.about-links {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.error-body {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1rem;
}

.error-shell {
  width: min(680px, 100%);
  text-align: center;
}

.error-code {
  display: inline-grid;
  min-width: 150px;
  min-height: 96px;
  place-items: center;
  margin-bottom: 1rem;
  border: 4px solid var(--pixel-line);
  background: var(--pixel-orange);
  color: #fff;
  font-size: 2.5rem;
  font-weight: 900;
  box-shadow: 6px 6px 0 var(--pixel-shadow);
}

.error-shell h1 {
  margin: 0 0 .75rem;
  font-size: clamp(1.45rem, 4vw, 2.2rem);
  font-weight: 900;
}

.error-shell p {
  margin: 0 auto 1.25rem;
  max-width: 34em;
  color: var(--pixel-muted);
  font-weight: 700;
}

@media (max-width: 1199.98px) {
  .hot-icon-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  .resource-card {
    grid-template-columns: 68px minmax(0, 1fr);
  }

  .resource-card .nes-btn {
    grid-column: 1 / -1;
    width: 100%;
  }

  .info-matrix {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .rank-main-list li {
    grid-template-columns: 44px 68px minmax(0, 1fr);
  }

  .rank-main-stat,
  .rank-main-action {
    grid-column: 3;
    justify-self: start;
    text-align: left;
  }
}

@media (max-width: 991.98px) {
  .pixel-nav .navbar-nav {
    padding: .75rem 0 1rem;
  }

  .pixel-nav .nav-link {
    min-height: 44px;
    border-top: 2px solid rgba(255, 255, 255, .25);
  }

  .vertical-title span {
    writing-mode: horizontal-tb;
    letter-spacing: 0;
  }

  .focus-slide,
  .focus-slide img {
    min-height: 360px;
  }

  .detail-hero,
  .topic-detail-head,
  .collection-row {
    grid-template-columns: 1fr;
  }

  .collection-action {
    justify-self: start;
  }

  .apk-grid,
  .topic-info-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767.98px) {
  .brand-picks {
    width: 100%;
  }

  .hot-icon-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tag-cloud p {
    align-items: flex-start;
  }

  .tag-cloud b {
    min-width: 48px;
  }

  .focus-slide,
  .focus-slide img {
    min-height: 330px;
  }

  .update-list li {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .update-list time {
    grid-column: 2;
  }

  .topic-card {
    grid-template-columns: 1fr;
  }

  .topic-card img {
    width: 100%;
  }

  .category-row,
  .resource-row,
  .included-item,
  .article-row {
    grid-template-columns: 1fr;
  }

  .resource-row img,
  .included-item > img {
    width: 72px;
    height: 72px;
  }

  .resource-action,
  .topic-download {
    width: 100%;
  }

  .article-row img {
    height: auto;
    aspect-ratio: 16 / 9;
  }

  .rank-main-list li {
    grid-template-columns: 38px 58px minmax(0, 1fr);
    gap: .65rem;
  }

  .rank-main-list li::before {
    width: 38px;
    height: 38px;
  }

  .rank-main-list img {
    width: 58px;
    height: 58px;
  }
}

@media (max-width: 420px) {
  .brand-mark {
    min-width: 54px;
  }

  .hot-icon-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .resource-card {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: .75rem;
  }

  .resource-card img {
    width: 58px;
    height: 58px;
  }

  .info-matrix,
  .apk-grid,
  .topic-info-grid {
    grid-template-columns: 1fr;
  }

  .download-state {
    width: 100%;
  }
}
