:root {
  --space-dark: #0d0221;
  --space-blue: #1a0a2e;
  --star-white: #f0e6ff;
  --nebula-pink: #ff2a6d;
  --comet-cyan: #05d9e8;
  --sun-gold: #f9f002;
  --planet-purple: #d300c5;
  --ink-muted: #a89cc8;
  --ink-on-light: #3d2e5c;
  --line-soft: rgba(5, 217, 232, 0.35);
  --g24-font: system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --g24-accent-text: #05d9e8;
  --g24-header-h: 56px;
  --g24-star-full: #f9f002;
  --g24-star-empty: #4a3d6b;
  --transition-fast: 0.15s ease;
}

*, *::before, *::after { box-sizing: border-box; }
html { width: 100%; overflow-x: hidden; scroll-behavior: smooth; }

body, .g24-body {
  background: var(--space-dark);
  color: var(--star-white);
  font-family: var(--g24-font);
  margin: 0;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  line-height: 1.55;
  padding-top: calc(var(--g24-header-h) + 2px);
  padding-bottom: env(safe-area-inset-bottom, 0);
}

body.g24-body:has(.anchorAdContent):not(:has(.g24-ad-slot--top)) {
  padding-top: calc(var(--g24-header-h) + 96px);
}
body.g24-body:has(.anchorAdContent):not(:has(.g24-ad-slot--top)) .anchorAdContent {
  position: fixed !important;
  top: calc(var(--g24-header-h) + 2px) !important;
  left: 0; right: 0; width: 100% !important;
  margin: 0 !important; z-index: 9999 !important;
}
body.g24-body:has(.g24-ad-slot--top) .anchorAdContent,
body.g24-body--detail:has(.g24-ad-slot--detail-top) .anchorAdContent { display: none !important; }

h1, h2, h3 { font-weight: 800; margin-top: 0; }
a { text-decoration: none; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }

.g24-page-wrap {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 20px;
}

.brief-comment-game {
  margin: 0;
  line-height: 1.45;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  font-size: 0.86rem;
  color: var(--ink-muted);
}

.article-list .special-card-content,
.article-list .carousel-card-content {
  padding: 12px 14px 16px;
}

.article-list .game-title,
.article-list .card-title,
.special-card .game-title,
.game-card .card-title,
.carousel-card .game-title,
.g24-neon-card .game-title,
.g24-overlay-card .game-title,
.g24-cabinet-card .game-title {
  display: block;
  max-width: 100%;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.special-card-content, .carousel-card-content, .card-content, .g24-neon-meta, .g24-overlay-body { min-width: 0; }

.module-description { margin: 0 0 1.25rem; color: var(--ink-muted); max-width: 58ch; }

/* Stars */
.game-star, .game-star .star-rating, .star-rating {
  display: inline-flex; align-items: center; gap: 2px; flex-wrap: wrap;
}
.game-star .star-icon, .game-star .star-full, .game-star .star-empty,
.game-star .fa, .game-star i, .star-rating i {
  font-style: normal; font-size: 0.9rem; line-height: 1;
}
.game-star .star-full::before, .game-star .fa-star::before, .star-rating .star-full::before {
  content: "★"; color: var(--g24-star-full);
}
.game-star .star-empty::before, .game-star .fa-star-o::before, .star-rating .star-empty::before {
  content: "☆"; color: var(--g24-star-empty);
}
.game-star.game-star--detail-hero { margin: 0 0 12px; }

/* Header */
.g24-site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  background: rgba(13, 2, 33, 0.92);
  border-bottom: 2px solid var(--nebula-pink);
  box-shadow: 0 0 20px rgba(255, 42, 109, 0.3);
}
.g24-header-inner {
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: var(--g24-header-h);
}
.g24-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  min-width: 0;
}
.g24-logo .logo-text {
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--comet-cyan);
  text-shadow: 0 0 12px var(--comet-cyan);
  max-width: min(240px, 36vw);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.logo-img {
  display: block;
  height: 40px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
  object-position: left center;
  flex-shrink: 0;
}
.g24-nav-bar {
  display: none;
  flex: 1;
  align-items: center;
  gap: 4px;
  min-width: 0;
  flex-wrap: nowrap;
}
@media (min-width: 768px) { .g24-nav-bar { display: flex; } }
.g24-nav-bar .nav-link,
.g24-nav-bar .nav-more-toggle {
  white-space: nowrap;
  flex: 0 0 auto;
}
.g24-nav-bar .nav-item--primary.is-overflow-hidden {
  display: none;
}
.g24-nav-bar .nav-more {
  position: relative;
  flex: 0 0 auto;
}
.g24-nav-bar .nav-more-toggle {
  cursor: pointer;
  border: none;
  font: inherit;
  background: transparent;
  color: inherit;
  box-shadow: none;
}
.g24-nav-bar .nav-more-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 160px;
  padding: 8px;
  background: var(--space-blue);
  border: 1px solid var(--nebula-pink);
  box-shadow: 0 0 16px rgba(255, 42, 109, 0.35);
  z-index: 1200;
}
.g24-nav-bar .nav-more.active .nav-more-menu {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.g24-nav-bar .nav-more-menu .nav-link {
  display: block;
  padding: 8px 12px;
}
.g24-nav-bar .nav-more-menu .nav-link:hover,
.g24-nav-bar .nav-more-menu .nav-link.active {
  color: var(--nebula-pink);
  border-color: var(--nebula-pink);
}
.g24-nav-bar .nav-link::after,
.g24-nav-bar .nav-more-toggle::after {
  display: none !important;
}
.g24-nav-bar .nav-link {
  padding: 8px 12px;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--ink-muted);
  border: 1px solid transparent;
}
.g24-nav-bar .nav-link.active,
.g24-nav-bar .nav-link:hover {
  color: var(--nebula-pink);
  border-color: var(--nebula-pink);
  box-shadow: 0 0 8px rgba(255, 42, 109, 0.4);
}
.g24-header-cta {
  flex-shrink: 0;
  margin-left: auto;
  padding: 8px 16px;
  background: var(--nebula-pink);
  color: #fff;
  font-weight: 800;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.g24-mobile-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 1000;
  display: flex;
  background: var(--space-blue);
  border-top: 2px solid var(--comet-cyan);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@media (min-width: 768px) { .g24-mobile-bar { display: none; } }
.g24-mobile-bar .mobile-nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 10px 4px;
  font-size: 0.7rem;
  color: var(--ink-muted);
}
.g24-mobile-bar .mobile-nav-item.active { color: var(--comet-cyan); }
.g24-mob-icon { font-size: 1.1rem; }

/* Hero */
.g24-hero-arcade {
  padding: 36px 0 32px;
  text-align: center;
  background: radial-gradient(ellipse at center, #2a1050 0%, var(--space-dark) 70%);
}
.g24-marquee-frame {
  display: inline-block;
  padding: 12px 24px;
  border: 3px solid var(--comet-cyan);
  box-shadow: 0 0 16px var(--comet-cyan), inset 0 0 12px rgba(5, 217, 232, 0.15);
}
.g24-hero-arcade .hero-title {
  margin: 0;
  font-size: clamp(1.5rem, 4.5vw, 2.4rem);
  color: var(--sun-gold);
  text-shadow: 0 0 20px var(--nebula-pink);
  max-width: min(100%, 20em);
}
.g24-hero-arcade .hero-subtitle { margin: 14px auto 0; max-width: 42em; color: var(--ink-muted); }
.g24-hero-arcade .hero-subtitle p { margin: 0; }
.g24-hero-search {
  display: flex;
  gap: 8px;
  max-width: 420px;
  margin: 18px auto 0;
}
.g24-hero-search .form-input {
  flex: 1;
  padding: 10px 14px;
  background: var(--space-blue);
  border: 2px solid var(--planet-purple);
  color: var(--star-white);
  font-family: inherit;
}
.g24-hero-search .hero-cta {
  padding: 10px 20px;
  background: var(--nebula-pink);
  border: none;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  font-family: inherit;
}

/* Sections */
.g24-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--line-soft);
  padding-bottom: 10px;
}
.g24-section-head h2 { font-size: 1.25rem; color: var(--comet-cyan); }
.g24-badge {
  display: inline-block;
  padding: 2px 8px;
  margin-right: 8px;
  background: var(--nebula-pink);
  color: #fff;
  font-size: 0.7rem;
  vertical-align: middle;
}
.module-link-more { color: var(--nebula-pink); font-weight: 700; font-size: 0.88rem; }

/* Featured neon row */
.g24-neon-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.g24-neon-card {
  border: 2px solid var(--comet-cyan);
  background: var(--space-blue);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.g24-neon-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 0 24px rgba(5, 217, 232, 0.5);
}
.g24-neon-thumb {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #1a0a2e;
}
.g24-neon-thumb img,
.g24-overlay-thumb img,
.g24-cabinet-thumb img,
.g24-pixel-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.g24-img-ph { background: #2a1050; }
.g24-neon-meta { padding: 10px 12px 14px; }
.g24-neon-meta .game-title { font-size: 0.95rem; margin: 0 0 6px; }

/* Overlay grid */
.g24-overlay-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.g24-overlay-card {
  position: relative;
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--line-soft);
}
.g24-overlay-thumb { aspect-ratio: 16 / 10; }
.g24-overlay-body {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 12px 14px 16px;
  background: linear-gradient(transparent, rgba(13, 2, 33, 0.95));
}
.g24-overlay-body .game-title { color: #fff; margin: 0 0 4px; }
.g24-overlay-body .brief-comment-game { color: rgba(240, 230, 255, 0.85); }
.g24-overlay-body .game-star { margin: 0 0 6px; }
.g24-overlay-body .g24-card-tags { margin: 0 0 6px; }

/* Cabinet grid */
.g24-cabinet-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
}
.g24-cabinet-card {
  background: var(--space-blue);
  border: 2px solid var(--planet-purple);
  overflow: hidden;
  transition: transform var(--transition-fast);
}
.g24-cabinet-card:hover { transform: scale(1.02); }
.g24-cabinet-thumb { aspect-ratio: 16 / 10; overflow: hidden; }
.article-list .g24-cabinet-card .game-title {
  margin: 0 0 4px;
  font-size: 0.95rem;
  line-height: 1.2;
}
.article-list .g24-cabinet-card .game-star {
  margin: 0 0 6px;
  line-height: 1;
}
.g24-pixel-card .carousel-card-content .game-title {
  margin: 0 0 4px;
  font-size: 0.95rem;
  line-height: 1.2;
}
.g24-pixel-card .carousel-card-content .game-star {
  margin: 0 0 6px;
  line-height: 1;
}
.g24-card-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 6px 0; }
.g24-tag-chip {
  font-size: 0.72rem;
  padding: 2px 8px;
  border: 1px solid var(--comet-cyan);
  color: var(--comet-cyan);
}

/* Carousel */
/* 覆写 CMS/基座可能注入的 .carousel-btn { position:absolute }，避免按钮压住卡片右侧 */
.g24-body .carousel-btn,
.g24-body .g24-carousel-btn {
  position: static;
  top: auto;
  right: auto;
  left: auto;
  transform: none;
}
.g24-pixel-carousel {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.g24-pixel-carousel .carousel-container {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  flex: 1;
  min-width: 0;
  padding: 8px 0;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.g24-pixel-carousel .carousel-container::-webkit-scrollbar { display: none; }
.g24-pixel-card {
  flex: 0 0 min(280px, 85vw);
  scroll-snap-align: start;
  background: var(--space-blue);
  border: 2px solid var(--nebula-pink);
  overflow: hidden;
}
.g24-pixel-thumb { aspect-ratio: 16 / 10; }
.g24-carousel-btn {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border: 2px solid var(--comet-cyan);
  background: transparent;
  color: var(--comet-cyan);
  cursor: pointer;
  font-size: 1rem;
}

/* Categories pills */
.g24-pill-cats { padding: 32px 0 56px; }
.g24-cat-heading { font-size: 1.1rem; margin-bottom: 16px; color: var(--sun-gold); }
.g24-pill-wrap { display: flex; flex-wrap: wrap; gap: 10px; }
.g24-pill {
  padding: 10px 18px;
  border: 2px solid var(--nebula-pink);
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.88rem;
  transition: background var(--transition-fast), box-shadow var(--transition-fast);
}
.g24-pill:hover {
  background: rgba(255, 42, 109, 0.2);
  box-shadow: 0 0 12px var(--nebula-pink);
}

.g24-pick-section { background: transparent; }
.g24-spotlight, .daily-special { padding: 24px 0; content-visibility: auto; contain-intrinsic-size: auto 520px; }

/* Tags page: top catalog layout */
.g24-tags-page { padding-top: 8px; padding-bottom: 72px; }
.g24-tags-top {
  padding-top: 8px;
  padding-bottom: 24px;
  border-bottom: 2px solid var(--line-soft);
}
.g24-tags-hero { margin-bottom: 4px; }
.g24-tags-hero h1 {
  margin: 10px 0 8px;
  font-size: clamp(1.5rem, 3.5vw, 2.1rem);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--star-white);
  text-shadow: 0 0 16px rgba(5, 217, 232, 0.35);
}
.g24-tags-hero .tag-h2 {
  margin: 0;
  max-width: 52ch;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--ink-muted);
}
.g24-tags-cat-nav { margin: 22px 0 18px; }
.g24-tags-cat-label {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--comet-cyan);
}
.g24-tags-cat-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0;
  border: 2px solid var(--comet-cyan);
  box-shadow: 0 0 12px rgba(5, 217, 232, 0.2);
}
.g24-tags-cat-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  font-weight: 600;
  font-size: 0.86rem;
  color: var(--ink-muted);
  background: var(--space-blue);
  border-right: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  transition: color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);
}
.g24-tags-cat-grid .g24-tags-cat-link:nth-child(5n) { border-right: none; }
.g24-tags-cat-link:hover {
  color: var(--star-white);
  background: rgba(255, 42, 109, 0.12);
  box-shadow: inset 0 0 12px rgba(255, 42, 109, 0.15);
}
.g24-tags-cat-link.active {
  color: var(--star-white);
  background: rgba(255, 42, 109, 0.22);
  box-shadow: inset 0 0 0 1px var(--nebula-pink);
}
.g24-cat-idx {
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--comet-cyan);
  flex-shrink: 0;
}
.g24-tags-cat-link.active .g24-cat-idx { color: var(--sun-gold); }
.g24-cat-name { min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.g24-tags-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.g24-filter-toggle {
  display: none;
  padding: 8px 14px;
  border: 2px solid var(--comet-cyan);
  background: transparent;
  color: var(--comet-cyan);
  font-family: inherit;
  font-weight: 700;
  font-size: 0.82rem;
  cursor: pointer;
}
.g24-view-panel {
  display: flex;
  border: 2px solid var(--line-soft);
}
.g24-view-btn {
  padding: 8px 16px;
  border: none;
  border-right: 1px solid var(--line-soft);
  background: transparent;
  color: var(--ink-muted);
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  font-size: 0.8rem;
}
.g24-view-btn:last-child { border-right: none; }
.g24-view-btn.is-active {
  background: var(--nebula-pink);
  color: #fff;
  box-shadow: 0 0 10px rgba(255, 42, 109, 0.45);
}
.g24-drawer-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1100;
  margin: 0;
  padding: 0;
  border: none;
  background: rgba(0, 0, 0, 0.7);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
body.g24-drawer-open .g24-drawer-backdrop { display: block; }
.g24-tags-drawer { display: none; }
.g24-drawer-panel {
  background: var(--space-blue);
  border: 2px solid var(--comet-cyan);
  box-shadow: 0 0 24px rgba(5, 217, 232, 0.25);
  width: min(320px, 100%);
  max-height: min(80vh, 520px);
  overflow-y: auto;
}
.g24-drawer-title {
  margin: 0;
  padding: 14px 16px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--comet-cyan);
  border-bottom: 1px solid var(--line-soft);
}
.g24-drawer-cat-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.g24-drawer-cat-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  color: var(--ink-muted);
  border-bottom: 1px solid var(--line-soft);
}
.g24-drawer-cat-link:hover,
.g24-drawer-cat-link.active {
  color: var(--star-white);
  background: rgba(255, 42, 109, 0.15);
}
.g24-tags-main-wrap { padding-top: 24px; padding-bottom: 8px; }
.g24-tags-main { min-width: 0; }
.g24-tags-catalog {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.g24-tags-catalog .g24-cabinet-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.g24-tags-catalog .g24-cabinet-thumb {
  aspect-ratio: 16 / 10;
  overflow: hidden;
}
.g24-tags-catalog .g24-cabinet-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.g24-tags-catalog .special-card-content {
  padding: 10px 12px 12px;
}
.g24-tags-catalog .game-title {
  margin: 0 0 4px;
  line-height: 1.2;
}
.g24-tags-catalog .game-star {
  margin: 0 0 6px;
  line-height: 1;
}
.g24-tags-catalog .g24-card-tags {
  margin: 4px 0;
}
.g24-tags-catalog .brief-comment-game {
  margin: 0;
}
.g24-tags-catalog.list-view,
#games-grid.g24-tags-catalog.list-view {
  grid-template-columns: 1fr !important;
  gap: 12px;
}
.g24-tags-catalog.list-view .g24-cabinet-card {
  flex-direction: row;
  align-items: stretch;
  width: 100%;
}
.g24-tags-catalog.list-view .g24-cabinet-thumb {
  flex: 0 0 clamp(120px, 32vw, 200px);
  width: clamp(120px, 32vw, 200px);
  max-width: clamp(120px, 32vw, 200px);
  min-height: 96px;
  aspect-ratio: 4 / 3;
  align-self: stretch;
}
.g24-tags-catalog.list-view .g24-cabinet-thumb img {
  width: 100%;
  height: 100%;
  min-height: 168px;
  object-fit: cover;
}
.g24-tags-catalog.list-view .special-card-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-width: 0;
  padding: 10px 12px;
}
.g24-tags-catalog .g24-empty--inline { grid-column: 1 / -1; }
@media (min-width: 769px) and (max-width: 1024px) {
  .g24-tags-cat-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .g24-tags-cat-grid .g24-tags-cat-link:nth-child(5n) { border-right: 1px solid var(--line-soft); }
  .g24-tags-cat-grid .g24-tags-cat-link:nth-child(3n) { border-right: none; }
  .g24-tags-catalog:not(.list-view) { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #games-grid.g24-tags-catalog.list-view { grid-template-columns: 1fr !important; }
}

/* Detail */
.g24-detail-banner {
  position: relative;
  height: min(42vh, 320px);
  overflow: hidden;
  margin-top: 0;
}
.g24-detail-banner-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.g24-detail-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 30%, var(--space-dark));
}
.g24-detail-page { padding: 24px 0 40px; }
.g24-detail-panel {
  margin-top: -40px;
  position: relative;
  z-index: 2;
  padding: 24px;
  background: var(--space-blue);
  border: 2px solid var(--nebula-pink);
}
.g24-detail-panel #game-title {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 3vw, 1.85rem);
  line-height: 1.25;
  word-break: break-word;
}
.g24-detail-crumb {
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line-soft);
  font-size: 0.85rem;
  color: var(--ink-muted);
}
.g24-detail-crumb .breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 4px 6px;
  list-style: none;
  padding: 0;
  margin: 0;
  min-width: 0;
}
.g24-detail-crumb .breadcrumb-item {
  min-width: 0;
  max-width: 100%;
}
.g24-detail-crumb .breadcrumb-item a {
  color: var(--comet-cyan);
  font-weight: 600;
}
.g24-detail-crumb .breadcrumb-item a:hover {
  color: var(--star-white);
}
.g24-detail-crumb .breadcrumb-item span[aria-current="page"] {
  color: var(--star-white);
  display: inline-block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}
.g24-detail-crumb .breadcrumb-separator {
  flex-shrink: 0;
  color: var(--ink-muted);
  opacity: 0.85;
}
.breadcrumb-list { display: flex; flex-wrap: wrap; align-items: center; gap: 4px; list-style: none; padding: 0; margin: 0; }
.g24-detail-tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0; }
.g24-tag-pill {
  padding: 4px 12px;
  border: 1px solid var(--comet-cyan);
  font-size: 0.8rem;
  color: var(--comet-cyan);
}
.g24-btn-play {
  display: inline-block;
  margin: 16px 0;
  padding: 14px 28px;
  background: var(--nebula-pink);
  border: none;
  color: #fff;
  font-weight: 800;
  font-size: 1rem;
  cursor: pointer;
  font-family: inherit;
  box-shadow: 0 0 20px rgba(255, 42, 109, 0.5);
}
.g24-detail-block { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--line-soft); }
.g24-detail-block h2 { font-size: 1.1rem; color: var(--comet-cyan); }
.rich-content { line-height: 1.7; overflow-x: auto; word-break: break-word; }

/* Modal */
.g24-game-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0, 0, 0, 0.85);
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.g24-game-modal.is-open { display: flex; }
.g24-modal-panel {
  width: min(960px, 100%);
  background: var(--space-blue);
  border: 2px solid var(--comet-cyan);
  position: relative;
}
.g24-modal-panel iframe { width: 100%; aspect-ratio: 16 / 9; border: none; display: block; }
.g24-modal-close {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 2;
  padding: 8px 12px;
  background: var(--nebula-pink);
  border: none;
  color: #fff;
  cursor: pointer;
  font-family: inherit;
}

/* Footer */
.g24-footer {
  margin-top: auto;
  background: var(--space-blue);
  border-top: 2px solid var(--nebula-pink);
  padding-top: 32px;
}
.g24-footer-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  padding-bottom: 24px;
}
.g24-footer-name { color: var(--comet-cyan); font-size: 1.1rem; }
.g24-footer-brand p { color: var(--ink-muted); font-size: 0.9rem; margin: 8px 0 12px; }
.footer-social { display: flex; flex-wrap: wrap; gap: 10px; }
.footer-social-link {
  font-size: 0.82rem;
  color: var(--nebula-pink);
  font-weight: 600;
}
.g24-footer-nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 0.88rem;
}
.g24-footer-nav a:hover { color: var(--comet-cyan); }
.g24-footer-copy {
  text-align: center;
  padding: 14px;
  border-top: 1px solid var(--line-soft);
  font-size: 0.82rem;
  color: var(--ink-muted);
}

/* Legal / ads / empty */
.g24-ad-slot {
  padding-top: 16px;
  padding-bottom: 16px;
  overflow: hidden;
}

.g24-ad-slot--top {
  padding-top: 12px;
  padding-bottom: 8px;
}

.g24-ad-slot--top.g24-page-wrap {
  padding-left: 16px;
  padding-right: 16px;
}

.g24-ad-slot--detail-top {
  padding-top: 12px;
  padding-bottom: 8px;
}

.g24-ad-slot iframe,
.g24-ad-slot ins,
.g24-ad-slot > div {
  max-width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.g24-legal-ad { padding-top: 20px; }
.g24-page-wrap > * + .legal-container { margin-top: 24px; }
.legal-container {
  padding: 28px 24px;
  margin-bottom: 48px;
  background: var(--space-blue);
  border: 2px solid var(--line-soft);
  line-height: 1.7;
}
.legal-container h1, .legal-container h2 { color: var(--comet-cyan); }
.g24-empty { text-align: center; padding: 48px 20px; }
.g24-empty-icon { font-size: 3rem; margin-bottom: 12px; }

.g24-back-top {
  position: fixed;
  bottom: 80px;
  right: 16px;
  z-index: 900;
  width: 44px;
  height: 44px;
  border: 2px solid var(--comet-cyan);
  background: var(--space-blue);
  color: var(--comet-cyan);
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-fast);
}
.g24-back-top.show { opacity: 1; pointer-events: auto; }
@media (min-width: 768px) { .g24-back-top { bottom: 24px; } }

.pagination-container { margin-top: 28px; }

@media (max-width: 768px) {
  .g24-nav-bar,
  .g24-header-cta {
    display: none !important;
  }

  .g24-site-header {
    height: auto;
  }

  .g24-header-inner {
    height: auto;
    min-height: var(--g24-header-h);
    max-height: none;
    padding: 6px 12px;
    justify-content: flex-start;
    align-items: center;
    gap: 8px;
  }

  .g24-logo .logo-text {
    font-size: 0.95rem;
    line-height: 1.15;
    display: block;
    max-width: calc(100vw - 72px);
  }

  .g24-logo .logo-img {
    height: 32px;
    max-width: 128px;
  }

  .g24-ad-slot,
  .g24-ad-slot--top {
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .g24-ad-slot--top.g24-page-wrap {
    padding-left: 12px;
    padding-right: 12px;
  }

  .g24-ad-slot--top + .g24-spotlight,
  .g24-ad-slot--top + .daily-special,
  .g24-ad-slot--top + .g24-pick-section {
    padding-top: 12px;
  }

  .g24-spotlight {
    padding-top: 12px;
    padding-bottom: 16px;
  }
  .g24-spotlight .g24-section-head {
    margin-bottom: 10px;
    padding-bottom: 8px;
  }
  .g24-spotlight .module-description {
    margin-bottom: 0.75rem;
    font-size: 0.88rem;
  }
  .g24-page-wrap {
    padding-left: max(16px, env(safe-area-inset-left, 0px));
    padding-right: max(16px, env(safe-area-inset-right, 0px));
  }
  .g24-neon-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .g24-neon-card {
    border-width: 1px;
  }
  .g24-neon-thumb {
    aspect-ratio: 16 / 9;
  }
  .g24-neon-meta {
    padding: 6px 8px 8px;
  }
  .g24-neon-meta .game-title {
    margin-bottom: 2px;
    font-size: 0.82rem;
    line-height: 1.15;
  }
  .g24-neon-meta .game-star .star-full::before,
  .g24-neon-meta .game-star .star-empty::before,
  .g24-neon-meta .game-star .fa-star::before,
  .g24-neon-meta .game-star .fa-star-o::before {
    font-size: 0.78rem;
  }
  .g24-cabinet-grid:not(.list-view),
  .g24-overlay-grid,
  #games-grid.g24-cabinet-grid:not(.list-view) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  /* overlay 卡片在窄屏下改为上图下文，避免标题被 overflow 裁切 */
  .g24-overlay-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }
  .g24-overlay-thumb {
    flex-shrink: 0;
    width: 100%;
  }
  .g24-overlay-body {
    position: static;
    flex: 1;
    background: var(--space-blue);
    padding: 10px 12px 12px;
  }
  .g24-overlay-body .game-title {
    color: var(--star-white);
    margin: 0 0 4px;
    font-size: 0.9rem;
  }
  .g24-overlay-body .brief-comment-game {
    color: var(--ink-muted);
  }
  .article-list .g24-cabinet-card .game-title,
  .g24-pixel-card .game-title {
    margin-bottom: 2px;
    font-size: 0.88rem;
    line-height: 1.15;
  }
  .article-list .g24-cabinet-card .game-star,
  .g24-pixel-card .game-star,
  .g24-neon-meta .game-star {
    margin-bottom: 0;
  }
  /* 轮播：左右按钮 + 中间轨道；卡片宽度相对轨道 100%，避免 85vw 裁切 */
  .g24-pixel-carousel {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 6px;
    align-items: center;
  }
  .g24-pixel-carousel .g24-carousel-btn {
    width: 36px;
    height: 36px;
    font-size: 0.85rem;
  }
  .g24-pixel-carousel .carousel-container {
    gap: 12px;
    padding: 4px 0 8px;
  }
  .g24-pixel-card {
    flex: 0 0 100%;
    max-width: 100%;
    scroll-snap-align: start;
  }
  .g24-detail-page {
    padding-top: 16px;
    padding-bottom: 32px;
  }
  .g24-detail-panel {
    margin-top: -24px;
    padding: 16px;
  }
  .g24-detail-panel #game-title {
    font-size: clamp(1.05rem, 4.2vw, 1.28rem);
    line-height: 1.3;
    margin-bottom: 8px;
  }
  .g24-detail-panel .game-star--detail-hero {
    margin-bottom: 8px;
  }
  .g24-detail-crumb {
    margin-bottom: 12px;
    padding-bottom: 10px;
  }
  .g24-detail-crumb .breadcrumb-list {
    row-gap: 6px;
  }
  .g24-detail-crumb .breadcrumb-item a span {
    word-break: break-word;
  }
  .g24-detail-crumb .breadcrumb-item span[aria-current="page"] {
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
    word-break: break-word;
  }
  .g24-tags-cat-nav { display: none; }
  .g24-filter-toggle { display: inline-block; }
  body.g24-drawer-open .g24-tags-drawer {
    display: flex;
    position: fixed;
    inset: 0;
    z-index: 1101;
    padding: 16px;
    align-items: flex-start;
    justify-content: flex-start;
    pointer-events: none;
  }
  body.g24-drawer-open .g24-drawer-panel { pointer-events: auto; }
  .g24-tags-cat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .g24-tags-cat-grid .g24-tags-cat-link:nth-child(5n) { border-right: 1px solid var(--line-soft); }
  .g24-tags-cat-grid .g24-tags-cat-link:nth-child(2n) { border-right: none; }
  .g24-tags-catalog:not(.list-view) { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #games-grid.g24-tags-catalog.list-view {
    display: grid;
    grid-template-columns: 1fr !important;
    gap: 12px;
  }
  .g24-tags-catalog.list-view .g24-cabinet-card {
    flex-direction: row;
    align-items: stretch;
  }
  .g24-tags-catalog.list-view .g24-cabinet-thumb {
    flex: 0 0 120px;
    width: 120px;
    max-width: 120px;
    min-width: 120px;
    min-height: 90px;
    aspect-ratio: 4 / 3;
  }
  .g24-tags-catalog.list-view .g24-cabinet-thumb img {
    width: 100%;
    height: 100%;
    min-height: 90px;
    object-fit: cover;
  }
  .g24-tags-catalog.list-view .special-card-content {
    flex: 1;
    padding: 10px 12px;
    min-width: 0;
  }
  .g24-tags-catalog.list-view .game-title {
    margin: 0 0 4px;
    font-size: 0.92rem;
    white-space: nowrap;
  }
  .g24-tags-catalog.list-view .game-star {
    margin: 0 0 6px;
  }
  .g24-tags-catalog.list-view .g24-card-tags {
    margin: 0 0 4px;
  }
  .g24-tags-catalog.list-view .brief-comment-game {
    -webkit-line-clamp: 2;
    font-size: 0.8rem;
  }
  .g24-footer-inner { grid-template-columns: 1fr; }
}
