/* — */

/* ── 1. CSS VARIABLES ── */
:root {
  --bg:           #0d1117;
  --bg-card:      #161b22;
  --bg-panel:     #1c2128;
  --accent:       #2ea043;
  --accent-dark:  #238636;
  --accent-hover: #3fb950;
  --accent2:      #1f6feb;
  --accent2-hover:#388bfd;
  --gold:         #e6b450;
  --gold-dim:     #c99a38;
  --text:         #e6edf3;
  --text-muted:   #8b949e;
  --text-light:   #c9d1d9;
  --border:       #30363d;
  --border-light: #21262d;
  --green:        #3fb950;
  --red:          #f85149;
  --radius:       8px;
  --radius-lg:    12px;
  --radius-pill:  999px;
  --shadow:       0 2px 12px rgba(0,0,0,.45);
  --shadow-lg:    0 8px 32px rgba(0,0,0,.6);
  --topbar-h:     38px;
  --header-h:     62px;
  --max-w:        1240px;
  --font-main:    'Noto Sans Thai', 'Mitr', sans-serif;
  --font-heading: 'Mitr', 'Noto Sans Thai', sans-serif;
  --transition:   0.2s ease;
}

/* ── 2. RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  font-size: 15px;
  -webkit-text-size-adjust: 100%;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-main);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  padding-top: calc(var(--topbar-h) + var(--header-h));
}

img { display: block; max-width: 100%; height: auto; object-fit: cover; }
a { color: var(--accent2); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--accent2-hover); }
ul, ol { list-style: none; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  line-height: 1.4;
  color: var(--text);
}

/* ── 3. TOP ANNOUNCEMENT BAR (gd-topbar) ── */
.gb-topbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  height: var(--topbar-h);
  background: #010409;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
}

.gb-topbar-inner {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.gb-topbar-msg {
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gb-topbar-btn {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  background: var(--accent);
  padding: 4px 14px;
  border-radius: var(--radius-pill);
  transition: background var(--transition);
  white-space: nowrap;
}
.gb-topbar-btn:hover { background: var(--accent-hover); color: #fff; }

/* ── 4. HEADER (gd-header) ── */
.gb-header {
  position: fixed;
  top: var(--topbar-h);
  left: 0;
  right: 0;
  z-index: 998;
  height: var(--header-h);
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
}

.gb-header-inner {
  width: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 20px;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* Logo */
.gb-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  flex-shrink: 0;
}
.gb-logo-icon { font-size: 22px; line-height: 1; }
.gb-logo-text {
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
}
.gb-logo:hover .gb-logo-text { color: var(--gold); }

/* Navigation */
.gb-nav { flex: 1; }
.gb-nav-list {
  display: flex;
  align-items: center;
  gap: 4px;
}
.gb-nav-link {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text-light);
  padding: 6px 12px;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
  white-space: nowrap;
}
.gb-nav-link:hover {
  background: var(--bg-panel);
  color: var(--text);
}

/* Header Right */
.gb-header-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.gb-header-cta {
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  background: var(--accent);
  padding: 7px 18px;
  border-radius: var(--radius-pill);
  transition: background var(--transition), transform var(--transition);
  white-space: nowrap;
}
.gb-header-cta:hover {
  background: var(--accent-hover);
  color: #fff;
  transform: translateY(-1px);
}

/* Hamburger */
.gb-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  cursor: pointer;
  padding: 6px 8px;
}
.gb-hamburger span {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--text-light);
  border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition);
}

/* ── 5. CATEGORY PILLS BAR (gd-cat-bar) ── */
.gb-cat-bar {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}

.gb-cat-bar-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.gb-cat-bar-inner::-webkit-scrollbar { display: none; }

.gb-cat-pill {
  flex-shrink: 0;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-muted);
  background: var(--bg-panel);
  border: 1px solid var(--border);
  padding: 5px 16px;
  border-radius: var(--radius-pill);
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  white-space: nowrap;
}
.gb-cat-pill:hover,
.gb-cat-pill--active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

/* ── 6. PAGE WRAP ── */
.gb-page-wrap {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 28px 20px 60px;
}
.gb-page-wrap--list { padding-top: 0; }
.gb-page-wrap--article { padding-top: 20px; }

/* ── 7. FEATURED BANNER (gd-featured-banner) ── */
.gb-featured-banner { margin-bottom: 32px; }

.gb-featured-bg {
  position: relative;
  min-height: 340px;
  background-size: cover;
  background-position: center;
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.gb-featured-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.85) 0%, rgba(0,0,0,.5) 55%, rgba(0,0,0,.15) 100%);
  display: flex;
  align-items: center;
}

.gb-featured-content {
  padding: 36px 48px;
  max-width: 560px;
}

.gb-featured-label {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--gold);
  background: rgba(230,180,80,.15);
  border: 1px solid rgba(230,180,80,.35);
  padding: 3px 12px;
  border-radius: var(--radius-pill);
  margin-bottom: 14px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.gb-featured-title {
  font-size: 1.85rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 12px;
  color: #fff;
}
.gb-featured-title a { color: #fff; }
.gb-featured-title a:hover { color: var(--gold); }

.gb-featured-excerpt {
  font-size: 14px;
  color: rgba(255,255,255,.8);
  line-height: 1.7;
  margin-bottom: 20px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.gb-featured-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ── 8. BUTTONS (gd-btn) ── */
.gb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: var(--font-heading);
  font-size: 13.5px;
  font-weight: 600;
  padding: 10px 22px;
  border-radius: var(--radius-pill);
  cursor: pointer;
  border: none;
  transition: background var(--transition), color var(--transition), transform var(--transition), box-shadow var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.gb-btn:hover { transform: translateY(-2px); }

.gb-btn--primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 3px 12px rgba(46,160,67,.4);
}
.gb-btn--primary:hover {
  background: var(--accent-hover);
  color: #fff;
  box-shadow: 0 5px 20px rgba(46,160,67,.55);
}

.gb-btn--outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.5);
}
.gb-btn--outline:hover {
  background: rgba(255,255,255,.1);
  border-color: #fff;
  color: #fff;
}

.gb-btn--full { width: 100%; }

/* ── 9. MAIN TWO-COLUMN LAYOUT (gd-main-layout) ── */
.gb-main-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px;
  align-items: start;
}

.gb-main-content { min-width: 0; }

/* ── 10. SECTION HEADER ── */
.gb-section { margin-bottom: 36px; }

.gb-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}

.gb-section-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
}

.gb-section-icon { font-style: normal; }

.gb-section-more {
  font-size: 12.5px;
  color: var(--accent2);
  white-space: nowrap;
}
.gb-section-more:hover { color: var(--accent2-hover); }

/* ── 11. INDEX H1 ── */
.gb-index-h1 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--gold);
  margin-bottom: 24px;
  line-height: 1.5;
}

/* ── 12. GUIDE ARTICLE LIST (gd-guide-list) ── */
.gb-guide-list { display: flex; flex-direction: column; gap: 16px; }

.gb-guide-card {
  display: flex;
  gap: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.gb-guide-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 20px rgba(46,160,67,.15);
}

.gb-guide-thumb-wrap {
  position: relative;
  flex-shrink: 0;
  width: 180px;
  height: 120px;
  overflow: hidden;
}
.gb-guide-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.gb-guide-card:hover .gb-guide-thumb { transform: scale(1.05); }

.gb-guide-body {
  flex: 1;
  padding: 14px 16px 14px 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.gb-guide-meta-top {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.gb-guide-provider {
  font-size: 11px;
  font-weight: 600;
  color: #fff;
  background: var(--accent);
  padding: 2px 10px;
  border-radius: var(--radius-pill);
}

.gb-guide-rtp {
  font-size: 11.5px;
  color: var(--gold);
  font-weight: 600;
}

.gb-guide-time {
  font-size: 11px;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: 4px;
}

.gb-guide-title {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.45;
}
.gb-guide-title a { color: var(--text); }
.gb-guide-title a:hover { color: var(--gold); }

.gb-guide-excerpt {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.gb-guide-meta-bot {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding-top: 6px;
}
.gb-guide-author { font-size: 11.5px; color: var(--text-muted); }
.gb-guide-date { font-size: 11px; color: var(--text-muted); }

/* Card badge */
.gb-card-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  background: var(--gold-dim);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  pointer-events: none;
  z-index: 2;
}

/* ── 13. RTP RANKING TABLE (gd-rtp-rank) ── */
.gb-rtp-table-wrap { overflow-x: auto; }

.gb-rtp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}

.gb-rtp-table thead th {
  background: var(--bg-panel);
  color: var(--text-muted);
  font-size: 11.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}

.gb-rtp-table tbody tr {
  border-bottom: 1px solid var(--border-light);
  transition: background var(--transition);
}
.gb-rtp-table tbody tr:hover { background: var(--bg-panel); }

.gb-rtp-table tbody td {
  padding: 12px 14px;
  vertical-align: middle;
}

.gb-rtp-rank-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  background: var(--bg-panel);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.gb-rtp-rank-num--gold  { background: #b8860b; color: #fff; border-color: #b8860b; }
.gb-rtp-rank-num--silver{ background: #708090; color: #fff; border-color: #708090; }
.gb-rtp-rank-num--bronze{ background: #8b4513; color: #fff; border-color: #8b4513; }

.gb-rtp-game-link { color: var(--text); font-weight: 600; }
.gb-rtp-game-link:hover { color: var(--gold); }

.gb-rtp-provider {
  font-size: 11.5px;
  color: var(--text-muted);
  background: var(--bg-panel);
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
}

.gb-rtp-trend { font-size: 12px; font-weight: 700; }
.gb-trend-up   { color: var(--green); }
.gb-trend-down { color: var(--red); }
.gb-trend-flat { color: var(--text-muted); }

/* ── 14. GAME GRID (gd-game-grid) ── */
.gb-game-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.gb-game-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}
.gb-game-card:hover {
  border-color: var(--accent);
  box-shadow: 0 4px 20px rgba(46,160,67,.18);
  transform: translateY(-2px);
}

.gb-game-thumb-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
.gb-game-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.gb-game-card:hover .gb-game-thumb { transform: scale(1.06); }

.gb-game-info {
  padding: 10px 12px 6px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.gb-game-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.4;
}
.gb-game-name:hover { color: var(--gold); }

.gb-game-prov { font-size: 11px; color: var(--text-muted); }

.gb-game-rtp-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  color: var(--text-muted);
}
.gb-game-rtp-row strong { color: var(--gold); }

.gb-game-cta {
  margin: 8px 10px 10px;
  display: block;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: var(--accent);
  padding: 7px 12px;
  border-radius: var(--radius-pill);
  transition: background var(--transition);
}
.gb-game-cta:hover { background: var(--accent-hover); color: #fff; }

/* ── 15. SIDEBAR (gd-sidebar) ── */
.gb-sidebar {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: calc(var(--topbar-h) + var(--header-h) + 20px);
}

.gb-sidebar-widget {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px 18px;
}

.gb-sidebar-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* CTA Widget */
.gb-cta-widget {
  background: linear-gradient(135deg, var(--accent-dark) 0%, #1a5729 100%);
  border-color: var(--accent);
  text-align: center;
  padding: 22px 20px;
}

.gb-cta-badge {
  display: inline-block;
  font-size: 10.5px;
  font-weight: 700;
  color: var(--gold);
  background: rgba(230,180,80,.15);
  border: 1px solid rgba(230,180,80,.4);
  padding: 2px 12px;
  border-radius: var(--radius-pill);
  margin-bottom: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.gb-cta-widget-title {
  font-size: 1.05rem;
  color: #fff;
  margin-bottom: 6px;
}

.gb-cta-widget-desc {
  font-size: 12px;
  color: rgba(255,255,255,.7);
  margin-bottom: 14px;
  line-height: 1.6;
}

.gb-cta-disclaimer {
  font-size: 10.5px;
  color: rgba(255,255,255,.5);
  margin-top: 8px;
  line-height: 1.5;
}

/* Top List */
.gb-top-list { display: flex; flex-direction: column; gap: 10px; }

.gb-top-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.gb-top-num {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
  background: var(--bg-panel);
  color: var(--text-muted);
  border: 1px solid var(--border);
  margin-top: 2px;
}
.gb-top-item:nth-child(1) .gb-top-num { background: #b8860b; color: #fff; border-color: #b8860b; }
.gb-top-item:nth-child(2) .gb-top-num { background: #708090; color: #fff; border-color: #708090; }
.gb-top-item:nth-child(3) .gb-top-num { background: #8b4513; color: #fff; border-color: #8b4513; }

.gb-top-link {
  font-size: 12.5px;
  color: var(--text-light);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.gb-top-link:hover { color: var(--gold); }

/* Provider List */
.gb-provider-list { display: flex; flex-direction: column; gap: 10px; }

.gb-provider-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.gb-provider-logo {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 800;
  color: #fff;
  letter-spacing: 0.03em;
}
.gb-provider-logo--pg { background: linear-gradient(135deg, #1a7a2e, #0d5c22); }
.gb-provider-logo--pp { background: linear-gradient(135deg, #c0392b, #922b21); }
.gb-provider-logo--jk { background: linear-gradient(135deg, #2980b9, #1a5276); }
.gb-provider-logo--sp { background: linear-gradient(135deg, #8e44ad, #6c3483); }
.gb-provider-logo--hs { background: linear-gradient(135deg, #d35400, #a04000); }

.gb-provider-name { font-size: 13px; color: var(--text-light); font-weight: 500; }
.gb-provider-name:hover { color: var(--accent2-hover); }

/* Tag Cloud */
.gb-tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }

.gb-tag {
  font-size: 11.5px;
  color: var(--text-muted);
  background: var(--bg-panel);
  border: 1px solid var(--border);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  transition: all var(--transition);
  white-space: nowrap;
}
.gb-tag:hover {
  color: #fff;
  background: var(--accent2);
  border-color: var(--accent2);
}

/* ── 16. FOOTER (gd-footer) ── */
.gb-footer {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  margin-top: 60px;
}

.gb-footer-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 48px 20px 32px;
}

.gb-footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 36px;
}

.gb-footer-logo {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 14px;
}
.gb-footer-logo:hover { color: var(--gold); }

.gb-footer-about {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.75;
  margin-bottom: 10px;
}

.gb-footer-age {
  font-size: 12px;
  color: var(--red);
  font-weight: 600;
}

.gb-footer-heading {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.gb-footer-links { display: flex; flex-direction: column; gap: 8px; }
.gb-footer-links a {
  font-size: 12.5px;
  color: var(--text-muted);
  transition: color var(--transition), padding-left var(--transition);
}
.gb-footer-links a:hover {
  color: var(--accent2-hover);
  padding-left: 4px;
}

/* Footer Copyright */
.gb-footer-copy {
  background: #010409;
  border-top: 1px solid var(--border);
}
.gb-footer-copy-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 14px 20px;
  text-align: center;
}
.gb-footer-copy p {
  font-size: 12px;
  color: var(--text-muted);
}
.gb-footer-copy a { color: var(--text-muted); }
.gb-footer-copy a:hover { color: var(--accent2-hover); }

/* ── 17. ARTICLE SHOW PAGE ── */

/* Breadcrumb */
.gb-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: var(--text-muted);
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.gb-breadcrumb a { color: var(--text-muted); }
.gb-breadcrumb a:hover { color: var(--accent2-hover); }
.gb-breadcrumb-sep { color: var(--border); }

/* Article Layout */
.gb-article-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px;
  align-items: start;
}

.gb-article-main { min-width: 0; }

/* Article Header */
.gb-article-header { margin-bottom: 24px; }

.gb-article-h1 {
  font-size: 1.65rem;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 14px;
  color: var(--text);
}

.gb-article-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 12.5px;
  color: var(--text-muted);
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}

.gb-article-meta span { display: flex; align-items: center; gap: 5px; }
.gb-meta-icon { color: var(--text-muted); flex-shrink: 0; }
.gb-cat-tag {
  color: #fff;
  background: var(--accent);
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 600;
}
.gb-cat-tag:hover { background: var(--accent-hover); color: #fff; }

/* Game Info Card */
.gb-game-card-info {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  gap: 20px;
  margin-bottom: 24px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.gb-game-card-thumb {
  flex-shrink: 0;
  width: 160px;
  height: 105px;
  border-radius: var(--radius);
  overflow: hidden;
}
.gb-game-card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.gb-game-card-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  flex: 1;
  min-width: 200px;
}

.gb-stat-item {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 10px 14px;
  background: var(--bg-panel);
  border-radius: var(--radius);
  border: 1px solid var(--border-light);
}

.gb-stat-icon { font-size: 16px; }
.gb-stat-label { font-size: 11px; color: var(--text-muted); }
.gb-stat-val { font-size: 14.5px; font-weight: 700; color: var(--text); }
.gb-score--hi { color: var(--green); }
.gb-score--lo { color: var(--gold); }

.gb-game-card-cta { flex-shrink: 0; min-width: 150px; text-align: center; }

/* Table of Contents */
.gb-toc {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  margin-bottom: 28px;
}

.gb-toc-title {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 7px;
}

.gb-toc-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-left: 4px;
  counter-reset: toc-counter;
}

.gb-toc-list li {
  counter-increment: toc-counter;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.gb-toc-list li::before {
  content: counter(toc-counter) ".";
  font-size: 11.5px;
  font-weight: 700;
  color: var(--accent);
  flex-shrink: 0;
  min-width: 18px;
}

.gb-toc-list a {
  font-size: 13px;
  color: var(--text-light);
  line-height: 1.5;
  transition: color var(--transition);
}
.gb-toc-list a:hover { color: var(--accent2-hover); }

/* Article Body */
.gb-article-body {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px 32px;
  margin-bottom: 24px;
  line-height: 1.9;
}

.gb-article-body h2 {
  font-size: 1.2rem;
  color: var(--gold);
  margin: 28px 0 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.gb-article-body h2:first-child { margin-top: 0; }

.gb-article-body h3 {
  font-size: 1.05rem;
  color: var(--text);
  margin: 22px 0 10px;
}

.gb-article-body p {
  font-size: 14.5px;
  color: var(--text-light);
  margin-bottom: 14px;
}

.gb-article-body ul,
.gb-article-body ol {
  padding-left: 22px;
  margin-bottom: 14px;
  list-style: disc;
}
.gb-article-body ol { list-style: decimal; }
.gb-article-body li { font-size: 14px; color: var(--text-light); margin-bottom: 6px; }

.gb-article-body a { color: var(--accent2); text-decoration: underline; }
.gb-article-body a:hover { color: var(--accent2-hover); }
.gb-article-body strong { color: var(--text); font-weight: 700; }

.gb-article-body table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
  margin: 16px 0;
}
.gb-article-body table th {
  background: var(--bg-panel);
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.gb-article-body table td {
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-light);
  color: var(--text-light);
}
.gb-article-body table tr:last-child td { border-bottom: none; }

/* In-Content CTA Banner */
.gb-incontent-cta {
  background: linear-gradient(135deg, var(--accent-dark) 0%, #0f4d1e 100%);
  border: 1px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  margin-bottom: 24px;
}

.gb-incontent-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.gb-incontent-cta-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.gb-incontent-cta-text strong {
  font-size: 15px;
  color: #fff;
  font-weight: 700;
}
.gb-incontent-cta-text span {
  font-size: 12.5px;
  color: rgba(255,255,255,.7);
}

/* Related Articles */
.gb-related-articles { margin-bottom: 28px; }

.gb-related-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.gb-related-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
}

.gb-related-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color var(--transition);
}
.gb-related-item:hover { border-color: var(--accent2); }

.gb-related-item img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
}

.gb-related-item-title {
  font-size: 11.5px;
  color: var(--text-light);
  padding: 0 8px 8px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.45;
}

/* Article Sidebar */
.gb-article-sidebar {
  position: sticky;
  top: calc(var(--topbar-h) + var(--header-h) + 20px);
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Score Summary */
.gb-score-summary { display: flex; flex-direction: column; gap: 12px; }

.gb-score-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.gb-score-label {
  font-size: 12px;
  color: var(--text-muted);
  min-width: 55px;
  flex-shrink: 0;
}

.gb-score-bar-wrap {
  flex: 1;
  height: 6px;
  background: var(--bg-panel);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.gb-score-bar {
  height: 100%;
  background: var(--accent);
  border-radius: var(--radius-pill);
  transition: width 0.5s ease;
}
.gb-score-bar--gold { background: var(--gold); }
.gb-score-bar--blue { background: var(--accent2); }

.gb-score-num {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  min-width: 28px;
  text-align: right;
}

.gb-score-overall {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 4px;
  padding: 12px;
  background: var(--bg-panel);
  border-radius: var(--radius);
  margin-top: 4px;
}
.gb-score-overall-label {
  font-size: 12px;
  color: var(--text-muted);
  margin-right: 8px;
}
.gb-score-overall-val {
  font-size: 2rem;
  font-weight: 800;
  color: var(--green);
}
.gb-score-overall-max {
  font-size: 14px;
  color: var(--text-muted);
}

/* Sidebar Guide List */
.gb-sidebar-guide-list { display: flex; flex-direction: column; gap: 10px; }

.gb-sidebar-guide-item {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-size: 12.5px;
}

.gb-sidebar-guide-num {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  min-width: 14px;
}
.gb-sidebar-guide-item a {
  color: var(--text-light);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.gb-sidebar-guide-item a:hover { color: var(--gold); }

/* ── 18. LIST / TAGS PAGE ── */
.gb-page-title {
  padding: 28px 0 20px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.gb-page-h1 {
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--text);
  margin: 8px 0 8px;
}
.gb-page-desc {
  font-size: 13.5px;
  color: var(--text-muted);
  line-height: 1.65;
}

.gb-list-grid-section { padding-top: 24px; }

.gb-list-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 36px;
}

.gb-list-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}
.gb-list-card:hover {
  border-color: var(--accent2);
  box-shadow: 0 4px 20px rgba(31,111,235,.15);
  transform: translateY(-2px);
}

.gb-list-card-thumb-wrap {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
.gb-list-card-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}
.gb-list-card:hover .gb-list-card-thumb { transform: scale(1.05); }

.gb-list-card-body {
  padding: 14px 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.gb-list-card-meta-top {
  display: flex;
  align-items: center;
  gap: 8px;
}

.gb-list-card-title { font-size: 14.5px; font-weight: 600; line-height: 1.45; }
.gb-list-card-title a { color: var(--text); }
.gb-list-card-title a:hover { color: var(--gold); }

.gb-list-card-excerpt {
  font-size: 12.5px;
  color: var(--text-muted);
  line-height: 1.65;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.gb-list-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px solid var(--border-light);
}
.gb-list-card-date { font-size: 11px; color: var(--text-muted); }
.gb-list-card-read { font-size: 12px; color: var(--accent2); font-weight: 600; }
.gb-list-card-read:hover { color: var(--accent2-hover); }

/* Pagination */
.gb-pagination {
  display: flex;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.gb-pagination a,
.gb-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--transition);
}
.gb-pagination a:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.gb-pagination .current,
.gb-pagination a.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

/* ── 19. SCROLL TO TOP ── */
.gb-scroll-top {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 990;
  width: 42px;
  height: 42px;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  color: #fff;
  background: var(--accent);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  box-shadow: 0 3px 14px rgba(46,160,67,.5);
  transition: background var(--transition), transform var(--transition);
}
.gb-scroll-top:hover {
  background: var(--accent-hover);
  transform: translateY(-3px);
}

/* ── 20. UTILITIES ── */
.gb-label {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 10px;
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.gb-label--green { background: rgba(63,185,80,.15); color: var(--green); border: 1px solid rgba(63,185,80,.3); }
.gb-label--gold  { background: rgba(230,180,80,.15); color: var(--gold); border: 1px solid rgba(230,180,80,.3); }
.gb-label--red   { background: rgba(248,81,73,.15);  color: var(--red);  border: 1px solid rgba(248,81,73,.3); }
.gb-label--blue  { background: rgba(31,111,235,.15); color: var(--accent2); border: 1px solid rgba(31,111,235,.3); }

.gb-divider { height: 1px; background: var(--border); margin: 28px 0; }

/* ── 21. SECTION ANCHORS — scroll offset ── */
#sec-overview,
#sec-howtoplay,
#sec-bonus,
#sec-rtp,
#sec-verdict {
  scroll-margin-top: calc(var(--topbar-h) + var(--header-h) + 20px);
}

/* ── 22. RTP TABLE EXTRAS ── */
.gb-rtp-table tbody td strong { color: var(--gold); }

/* ── 23. MOBILE RESPONSIVE ── */
@media (max-width: 1024px) {
  .gb-main-layout,
  .gb-article-layout {
    grid-template-columns: 1fr 260px;
    gap: 22px;
  }

  .gb-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
  }

  .gb-game-grid { grid-template-columns: repeat(3, 1fr); }
  .gb-related-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  body {
    padding-top: calc(var(--topbar-h) + var(--header-h));
    font-size: 14px;
  }

  .gb-topbar-msg { font-size: 11px; }

  .gb-header-inner { gap: 12px; }

  .gb-nav {
    position: fixed;
    top: calc(var(--topbar-h) + var(--header-h));
    left: 0;
    right: 0;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
    padding: 14px 20px;
    transform: translateY(-120%);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
    z-index: 997;
    box-shadow: var(--shadow-lg);
  }
  .gb-nav.gb-nav--open {
    transform: translateY(0);
    opacity: 1;
  }
  .gb-nav-list {
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
  }
  .gb-nav-link {
    width: 100%;
    padding: 10px 12px;
    font-size: 14px;
  }

  .gb-hamburger { display: flex; }
  .gb-header-cta { display: none; }

  .gb-cat-bar-inner { padding: 8px 16px; }

  .gb-page-wrap { padding: 20px 16px 48px; }

  .gb-featured-bg { min-height: 260px; }
  .gb-featured-content { padding: 24px 22px; }
  .gb-featured-title { font-size: 1.3rem; }
  .gb-featured-excerpt { display: none; }
  .gb-featured-actions { flex-wrap: wrap; }

  .gb-main-layout,
  .gb-article-layout { grid-template-columns: 1fr; }

  .gb-sidebar,
  .gb-article-sidebar { position: static; }

  .gb-guide-card { flex-direction: column; }
  .gb-guide-thumb-wrap { width: 100%; height: 180px; }
  .gb-guide-body { padding: 12px; }

  .gb-game-grid { grid-template-columns: repeat(2, 1fr); }
  .gb-list-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .gb-related-grid { grid-template-columns: repeat(3, 1fr); }

  .gb-article-body { padding: 18px 16px; }

  .gb-game-card-info { flex-direction: column; }
  .gb-game-card-thumb { width: 100%; height: 160px; }
  .gb-game-card-stats { grid-template-columns: repeat(2, 1fr); }
  .gb-game-card-cta { width: 100%; }

  .gb-incontent-cta-inner { flex-direction: column; align-items: flex-start; }

  .gb-rtp-table th:last-child,
  .gb-rtp-table td:last-child { display: none; }

  .gb-footer-grid { grid-template-columns: 1fr; gap: 28px; }
  .gb-footer-inner { padding: 32px 16px 24px; }

  .gb-scroll-top { width: 38px; height: 38px; font-size: 17px; bottom: 18px; right: 18px; }
}

@media (max-width: 480px) {
  .gb-game-grid { grid-template-columns: repeat(2, 1fr); }
  .gb-list-grid { grid-template-columns: 1fr; }
  .gb-related-grid { grid-template-columns: repeat(2, 1fr); }
  .gb-article-h1 { font-size: 1.35rem; }
  .gb-featured-title { font-size: 1.15rem; }
  .gb-topbar-msg { display: none; }
  .gb-topbar-inner { justify-content: center; }
}

/* ── 24. PRINT RESET (optional) ── */
@media print {
  .gb-topbar,
  .gb-header,
  .gb-cat-bar,
  .gb-sidebar,
  .gb-article-sidebar,
  .gb-scroll-top,
  .gb-footer { display: none !important; }
  body { padding-top: 0; background: #fff; color: #000; }
  .gb-article-body { border: none; padding: 0; }
}


/* ══════════════════════════════════════════════════════════════
   BNAV MOBILE — gd theme
══════════════════════════════════════════════════════════════ */
.gb-bnav { display: none; }

@media (max-width: 960px) {
  .gb-bnav {
    display: flex !important;
    position: fixed !important;
    left: 10px !important;
    right: 10px !important;
    bottom: calc(8px + env(safe-area-inset-bottom, 0px)) !important;
    height: 52px !important;
    padding: 0 6px !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 4px !important;
    background: rgba(6,12,8,0.92) !important;
    border: 1px solid rgba(74,163,62,0.28) !important;
    border-radius: 14px !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.6), 0 0 0 1px rgba(255,255,255,0.04) !important;
    z-index: 9999 !important;
  }
  .gb-bnav-link {
    flex: 1;
    min-width: 0;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 3px;
    border-radius: 10px;
    color: rgba(255,255,255,0.52);
    font-weight: 700;
    font-size: 9.5px;
    transition: background .15s, color .15s;
    -webkit-tap-highlight-color: transparent;
    text-decoration: none;
    padding: 0 4px;
  }
  .gb-bnav-ico { font-size: 17px; line-height: 1; }
  .gb-bnav-txt {
    font-size: 9.5px; line-height: 1;
    white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis; max-width: 100%;
  }
  .gb-bnav-link:hover,
  .gb-bnav-link.active {
    color: #fff;
    background: rgba(255,255,255,0.10);
  }
  .gb-bnav-link--cta {
    flex: 1.3;
    color: #fff !important;
    background: linear-gradient(135deg,#4aa33e,#2d7a24) !important;
    border-radius: 10px;
    box-shadow: 0 4px 14px rgba(0,0,0,0.35);
    font-size: 10px;
  }
  .gb-bnav-link--cta:hover { transform: translateY(-1px); }

  body {
    padding-bottom: calc(52px + 16px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

@media (max-width: 390px) {
  .gb-bnav { left: 8px !important; right: 8px !important; }
  .gb-bnav-ico { font-size: 16px !important; }
  .gb-bnav-txt { font-size: 9px !important; }
}



/* ══════════════════════════════════════════════════════════════
   FOOTER MOBILE DEEP — gd / gd-footer
══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Footer wrapper */
  .gb-footer { margin-top: 16px !important; }

  /* Grid: 2 cols */
  .gb-footer-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 18px 20px !important;
    padding: 22px 14px 16px !important;
  }

  /* About / first col: full-width condensed row */
  .gb-footer-col:first-child {
    grid-column: 1 / -1 !important;
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    padding-bottom: 14px !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  }
  /* Hide long description text on mobile */
  .gb-footer-col:first-child .gb-footer-about,
  .gb-footer-col:first-child .gb-footer-desc,
  .gb-footer-col:first-child .gb-footer-age,
  .gb-footer-col:first-child .fb-footer-desc {
    display: none !important;
  }
  .gb-footer-col:first-child .gb-footer-logo,
  .gb-footer-col:first-child .gb-footer-title:first-child {
    margin-bottom: 0 !important;
    flex-shrink: 0 !important;
  }

  /* Other cols: titles smaller */
  .gb-footer-col:not(:first-child) .gb-footer-heading,
  .gb-footer-col:not(:first-child) .gb-footer-title {
    font-size: 11px !important;
    margin-bottom: 9px !important;
    letter-spacing: .6px !important;
  }

  /* Links: horizontal wrap pills */
  .gb-footer-links,
  .gb-footer-col:not(:first-child) .gb-footer-links {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    gap: 5px !important;
  }
  .gb-footer-links a,
  .gb-footer-links li a,
  .gb-footer-col:not(:first-child) .gb-footer-links a,
  .gb-footer-col:not(:first-child) .gb-footer-links li a {
    display: inline-block !important;
    font-size: 11.5px !important;
    padding: 3px 10px !important;
    background: rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    border-radius: 5px !important;
    color: rgba(255,255,255,0.55) !important;
    transition: color .15s, border-color .15s !important;
  }
  .gb-footer-links a:hover,
  .gb-footer-links li a:hover,
  .gb-footer-col:not(:first-child) .gb-footer-links a:hover,
  .gb-footer-col:not(:first-child) .gb-footer-links li a:hover {
    color: #fff !important;
    border-color: rgba(255,255,255,0.25) !important;
  }
  /* Hide ::before arrows if any */
  .gb-footer-links a::before,
  .gb-footer-col:not(:first-child) .gb-footer-links a::before {
    display: none !important;
  }

  /* Footer bottom bar */
  .gb-footer-copy,
  .gb-footer-copy-inner,
  .gb-footer-bottom {
    flex-direction: column !important;
    text-align: center !important;
    gap: 3px !important;
    padding: 10px 14px !important;
    font-size: 11px !important;
  }
}

@media (max-width: 390px) {
  .gb-footer-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    padding: 18px 12px 14px !important;
  }
  .gb-footer-col:first-child { flex-direction: column; align-items: flex-start; gap: 6px; }
  .gb-footer-links a,
  .gb-footer-links li a {
    font-size: 11px !important;
    padding: 2px 8px !important;
  }
}

/* — */
@media (max-width: 480px) {
  /* Override grid to single column card list */
  .gb-list-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
  /* Card style */
  .gb-list-card {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 8px 12px;
    align-items: start;
    background: var(--bg-card, #0e1a12);
    border: 1px solid var(--border, rgba(74,163,62,0.2));
    border-radius: 10px;
    overflow: hidden;
    padding: 12px;
  }
  /* Thumbnail */
  .gb-list-card-thumb-wrap {
    width: 100px;
    height: 68px;
    grid-row: 1 / 4;
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
  }
  .gb-list-card-thumb { width: 100%; height: 100%; object-fit: cover; }
  .gb-card-badge { display: none; }
  /* Title */
  .gb-list-card-title { font-size: 13px; line-height: 1.4; margin: 0 0 4px; }
  /* Excerpt: 2 lines */
  .gb-list-card-excerpt {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 11px;
    color: var(--text3, rgba(255,255,255,0.5));
    margin: 0 0 4px;
  }
  /* Footer: meta inline */
  .gb-list-card-foot { display: flex; flex-direction: row; align-items: center; gap: 8px; flex-wrap: wrap; }
  .gb-list-card-date { font-size: 10px; }
  .gb-list-card-read { font-size: 11px; padding: 3px 10px; flex: 1; text-align: center; white-space: nowrap; }
  /* Filter bar: horizontal scroll */
  .gb-cat-bar {
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    gap: 6px !important;
  }
  .gb-cat-bar::-webkit-scrollbar { display: none; }
  .gb-cat-pill { flex-shrink: 0 !important; }
}

/* — */

/* ── List hero header ── */
.gb-list-hd { background: linear-gradient(135deg, #0a1f0a 0%, #081508 50%, #0c180c 100%); border: 1px solid rgba(31,111,235,.2); border-radius: var(--radius-lg); padding: 32px 28px; margin-bottom: 20px; }
.gb-list-hd-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.gb-list-hd-left { flex: 1; min-width: 0; }
.gb-list-hd-badge { display: inline-block; font-size: 11px; font-weight: 700; color: var(--accent2); background: rgba(31,111,235,.12); border: 1px solid rgba(31,111,235,.25); border-radius: 20px; padding: 3px 12px; margin-bottom: 10px; text-transform: uppercase; letter-spacing: .5px; }
.gb-list-hd-title { font-size: 28px; font-weight: 800; color: var(--text); margin-bottom: 8px; line-height: 1.2; }
.gb-list-hd-desc { font-size: 13px; color: var(--text-muted); line-height: 1.65; }
.gb-list-hd-stats { display: flex; align-items: center; gap: 0; flex-shrink: 0; background: var(--bg-panel); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 14px 20px; }
.gb-list-hd-stat { text-align: center; padding: 0 18px; }
.gb-list-hd-stat-val { display: block; font-size: 22px; font-weight: 900; color: var(--gold); line-height: 1.1; }
.gb-list-hd-stat-lbl { display: block; font-size: 10px; color: var(--text-muted); margin-top: 3px; text-transform: uppercase; letter-spacing: .5px; }
.gb-list-hd-stat-div { width: 1px; height: 36px; background: var(--border); }

/* ── Card overlay play button ── */
.gb-card-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .2s; }
.gb-list-card:hover .gb-card-overlay { opacity: 1; }
.gb-card-play { font-size: 13px; font-weight: 700; color: #fff; background: var(--accent2); border-radius: 20px; padding: 6px 14px; }

/* ── Card meta: score badge ── */
.gb-guide-score { font-size: 11px; color: var(--gold); font-weight: 600; background: rgba(212,175,55,.12); border: 1px solid rgba(212,175,55,.22); border-radius: 10px; padding: 2px 7px; }

/* ── List SEO box ── */
.gb-list-seo-box { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 18px 20px; margin-top: 12px; }
.gb-list-seo-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.gb-list-seo-text { font-size: 12.5px; color: var(--text-muted); line-height: 1.7; margin: 0; }

/* ── Tag intro block ── */
.gb-tag-intro { background: var(--bg-panel); border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: var(--radius-lg); padding: 16px 20px; margin-bottom: 18px; }
.gb-tag-intro-title { font-size: 14px; font-weight: 700; color: var(--gold); margin-bottom: 8px; }
.gb-tag-intro-desc { font-size: 13px; color: var(--text-muted); line-height: 1.75; margin: 0; }
.gb-tag-intro-desc strong { color: var(--text); }
.gb-tag-intro-desc a { color: var(--accent2); }
.gb-tag-intro-desc a:hover { text-decoration: underline; }

/* ── Show page: game hero ── */
.gb-game-hero { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 24px; }
.gb-game-hero-body { display: flex; gap: 20px; padding: 20px; align-items: flex-start; }
.gb-game-hero-cover { position: relative; flex-shrink: 0; width: 220px; border-radius: var(--radius); overflow: hidden; }
.gb-game-hero-cover img { width: 100%; height: auto; display: block; }
.gb-game-hero-badges { position: absolute; top: 8px; left: 8px; display: flex; gap: 5px; }
.gb-game-badge { font-size: 10px; font-weight: 800; border-radius: 4px; padding: 2px 7px; }
.gb-game-badge--hot { background: var(--red, #e74c3c); color: #fff; }
.gb-game-badge--free { background: var(--green); color: #fff; }
.gb-game-hero-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 10px; }
.gb-game-hero-cat { font-size: 12px; color: var(--text-muted); }
.gb-game-hero-scores { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.gb-game-hero-score-pill { display: inline-flex; align-items: baseline; gap: 2px; background: var(--bg-panel); border: 1px solid var(--border); border-radius: 8px; padding: 6px 12px; }
.gb-game-hero-score-val { font-size: 22px; font-weight: 900; color: var(--gold); line-height: 1; }
.gb-game-hero-score-lbl { font-size: 11px; color: var(--text-muted); }
.gb-game-hero-rtp { font-size: 13px; color: var(--green); font-weight: 700; background: rgba(39,174,96,.1); border: 1px solid rgba(39,174,96,.22); border-radius: 12px; padding: 4px 10px; }
.gb-game-hero-desc { font-size: 13px; color: var(--text-muted); line-height: 1.65; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.gb-game-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.gb-btn--hero { font-size: 14px !important; padding: 11px 24px !important; }
.gb-btn--ghost { border: 1px solid rgba(212,175,55,.4); color: var(--gold) !important; background: transparent; border-radius: 30px; padding: 10px 20px; font-size: 13px; font-weight: 700; display: inline-block; transition: .2s; }
.gb-btn--ghost:hover { background: rgba(212,175,55,.1); }

/* ── Show page: quick stat strip ── */
.gb-game-hero-strip { display: flex; align-items: center; background: var(--bg-panel); border-top: 1px solid var(--border); padding: 12px 20px; gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
.gb-ghs-item { text-align: center; flex: 1; padding: 0 14px; min-width: 0; }
.gb-ghs-lbl { display: block; font-size: 10px; color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 3px; white-space: nowrap; }
.gb-ghs-val { display: block; font-size: 14px; font-weight: 800; color: var(--text); white-space: nowrap; }
.gb-ghs-val--green { color: var(--green); }
.gb-ghs-val--gold { color: var(--gold); }
.gb-ghs-val--accent { color: var(--accent2); }
.gb-ghs-div { width: 1px; height: 32px; background: var(--border); flex-shrink: 0; }

/* ── Show page: mobile-only CTA ── */
.gb-show-mobile-cta { display: none; margin-bottom: 22px; }
.gb-show-mobile-cta-btn { display: block; width: 100%; text-align: center; background: linear-gradient(135deg, var(--accent), var(--accent2)); color: #fff !important; font-weight: 800; font-size: 15px; padding: 14px 20px; border-radius: 30px; box-sizing: border-box; }

/* ── Quick data table in sidebar ── */
.gb-quick-table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.gb-quick-table tr { border-bottom: 1px solid var(--border-light); }
.gb-quick-table tr:last-child { border-bottom: none; }
.gb-quick-table td { padding: 7px 4px; color: var(--text-muted); vertical-align: top; }
.gb-quick-table td:first-child { color: var(--text-muted); min-width: 80px; }
.gb-quick-table td.green { color: var(--green); font-weight: 700; }
.gb-quick-table td.gold { color: var(--gold); font-weight: 700; }
.gb-quick-table td.accent { color: var(--accent2); font-weight: 700; }

/* cat-pill active state */
.gb-cat-pill.active { background: var(--accent2); border-color: var(--accent2); color: #fff; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE — 900px
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .gb-list-hd { padding: 22px 18px; }
  .gb-list-hd-title { font-size: 22px; }
  .gb-list-hd-stats { padding: 10px 14px; }
  .gb-list-hd-stat { padding: 0 12px; }
  .gb-list-hd-stat-val { font-size: 18px; }
  .gb-game-hero-cover { width: 180px; }
  .gb-ghs-item { padding: 0 10px; }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — 768px
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* List hero */
  .gb-list-hd { padding: 18px 14px; }
  .gb-list-hd-inner { flex-direction: column; gap: 14px; align-items: flex-start; }
  .gb-list-hd-title { font-size: 20px; }
  .gb-list-hd-stats { width: 100%; box-sizing: border-box; justify-content: space-around; padding: 10px 0; }
  .gb-list-hd-stat { padding: 0 8px; }
  .gb-list-hd-stat-val { font-size: 16px; }

  /* Game hero: stack vertically */
  .gb-game-hero-body { flex-direction: column; padding: 14px; gap: 14px; }
  .gb-game-hero-cover { width: 100%; max-width: 260px; margin: 0 auto; }
  .gb-game-hero-actions { flex-direction: column; }
  .gb-btn--hero { display: block !important; width: 100% !important; text-align: center !important; box-sizing: border-box !important; }
  .gb-btn--ghost { display: block; width: 100%; text-align: center; box-sizing: border-box; }
  .gb-game-hero-strip { padding: 10px 10px; }
  .gb-ghs-item { padding: 0 6px; }
  .gb-ghs-val { font-size: 12px; }

  /* Mobile CTA: show on mobile */
  .gb-show-mobile-cta { display: block; }

  /* Tag intro */
  .gb-tag-intro { padding: 12px 14px; }
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE — 480px
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  .gb-list-hd-title { font-size: 17px; }
  .gb-list-hd-badge { font-size: 10px; }
  .gb-ghs-lbl { display: none; }
  .gb-ghs-val { font-size: 11px; }
  .gb-game-hero-strip { padding: 8px 6px; }
}

/* ====== gd- comments ====== */
.gb-comments-section { background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px; padding: 16px; margin-top: 22px; }
.gb-comments-title { font-size: 15px; font-weight: 800; color: #e6edf3; margin-bottom: 14px; }
.gb-comments-list { display: flex; flex-direction: column; gap: 12px; }
.gb-cmt { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08); border-radius: 8px; padding: 12px; }
.gb-cmm { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; font-size: 13px; }
.gb-cmm strong { color: #e6edf3; font-size: 14px; }
.gb-cmm .gb-se, .gb-cmm .gb-sg { background: #27ae60; padding: 2px 8px; border-radius: 4px; font-size: 12px; font-weight: 700; color: #fff; }
.gb-cmm .gb-sa { background: #f39c12; padding: 2px 8px; border-radius: 4px; font-size: 12px; font-weight: 700; color: #fff; }
.gb-cmd { color: #6e7681; font-size: 12px; }
.gb-cmt p { color: #8b949e; font-size: 13px; line-height: 1.5; margin: 0; }
