/* === fonts.css === */
/*
  Modern browser typography without local font payload.
  Font lama berbasis file woff2 sudah dicabut supaya render awal lebih ringan,
  tidak menunggu preload font, dan lebih stabil di Android/iOS.
*/
:root {
  --font-system: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  --font-main: var(--font-system);
  --font-display: var(--font-system);
  --font-display-italic: var(--font-system);
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

/* === theme.css === */
/*
  Public visual theme source of truth.
  Dibangun dari bahan CSS referensi: base #101014, glass/backplate, mask blur, hover ring,
  carousel control, dan ukuran banner fleksibel.
*/
:root {
  color-scheme: dark;

  /* Reference palette */
  --theme-bg: #101014;
  --theme-bg-soft: #121216;
  --theme-panel: #28282c;
  --theme-panel-2: #404044;
  --theme-text: #ffffff;
  --theme-muted: rgba(255,255,255,.75);
  --theme-subtle: rgba(255,255,255,.52);
  --theme-line: rgba(255,255,255,.10);
  --theme-line-strong: rgba(255,255,255,.16);
  --theme-blue: #0055fe;
  --theme-sky: #0ea4eb;
  --theme-cyan: #33daff;
  --theme-success: #36ff82;
  --theme-warning: #facc15;
  --theme-danger: #df242f;

  /* Reference blur/backplate */
  --theme-blur-xs: blur(.25rem);
  --theme-blur-sm: blur(.5rem);
  --theme-blur-md: blur(2rem);
  --theme-blur-xl: blur(64px);
  --theme-backplate: rgba(255,255,255,.10);
  --theme-backplate-hover: rgba(255,255,255,.15);
  --theme-backplate-strong: rgba(255,255,255,.20);
  --theme-dark-glass: rgba(16,16,20,.72);
  --theme-dark-glass-strong: rgba(16,16,20,.88);
  --theme-outline: rgba(255,255,255,.35);

  /* Typography: modern system stack, no local/external font payload */
  --font-main: var(--font-system);
  --font-display: var(--font-system);
  --font-display-italic: var(--font-system);
  --text-size-body: clamp(14px, .88vw, 15px);
  --text-size-body-mobile: 14px;
  --text-size-ui: clamp(12px, .78vw, 13.5px);
  --text-size-caption: clamp(10.8px, .70vw, 12px);
  --text-size-overline: clamp(9.8px, .62vw, 10.8px);
  --text-line-body: 1.5;
  --text-line-tight: 1.12;
  --text-line-ui: 1.18;
  --text-letter-tight: -.015em;
  --text-letter-ui: -.003em;
  --text-letter-overline: .04em;
  --text-weight-body: 450;
  --text-weight-ui: 600;
  --text-weight-strong: 680;
  --text-weight-display: 760;

  /* App surfaces */
  --surface: rgba(16,16,20,.78);
  --surface-2: rgba(18,18,22,.62);
  --surface-3: rgba(24,24,28,.54);
  --surface-solid: var(--theme-bg-soft);
  --text: var(--theme-text);
  --muted: var(--theme-muted);
  --subtle: var(--theme-subtle);
  --line: var(--theme-line);
  --line-strong: var(--theme-line-strong);

  /* Accent kept neutral-white with blue reflection support */
  --accent: #f4f4f5;
  --accent-2: #ffffff;
  --accent-contrast: #101014;
  --danger: var(--theme-danger);
  --good: var(--theme-success);
  --warn: var(--theme-warning);

  /* Shared glass surfaces */
  --glass-bg: linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.045));
  --glass-bg-strong: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.06));
  --surface-menu-bg: rgba(16,16,20,.74);
  --surface-menu-border: rgba(255,255,255,.12);

  /* Header */
  --header-glass-bg: rgba(16,16,20,.70);
  --header-glass-bg-elevated: rgba(16,16,20,.84);
  --header-glass-border: rgba(255,255,255,.10);
  --header-glass-border-strong: rgba(255,255,255,.16);
  --header-glass-blur: blur(2rem) saturate(155%);
  --header-mobile-glass-bg: rgba(16,16,20,.90);
  --header-mobile-drawer-bg: rgba(16,16,20,.96);
  --header-control-bg: rgba(255,255,255,.10);
  --header-control-bg-hover: rgba(255,255,255,.15);
  --header-control-border: rgba(255,255,255,.12);
  --header-control-border-hover: rgba(255,255,255,.20);
  --header-control-text: rgba(255,255,255,.82);
  --header-control-text-hover: #fff;
  --header-focus-ring: 0 0 0 2px rgba(255,255,255,.14);
  --header-register-bg: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.075));
  --header-register-bg-hover: linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.10));
  --header-register-border: rgba(255,255,255,.20);
  --header-register-border-hover: rgba(255,255,255,.28);
  --header-register-text: #fff;
  --header-register-text-hover: #fff;
  --header-register-shadow: inset 0 1px 0 rgba(255,255,255,.14);
  --header-register-shadow-hover: inset 0 1px 0 rgba(255,255,255,.18);

  /* Public game-card visual contract */
  --game-card-bg: rgba(255,255,255,.058);
  --game-card-bg-hover: rgba(255,255,255,.085);
  --game-card-bg-active: rgba(255,255,255,.10);
  --game-card-border: rgba(255,255,255,.10);
  --game-card-border-hover: rgba(255,255,255,.18);
  --game-card-outline: rgba(255,255,255,.18);
  --game-card-text: #fff;
  --game-card-media-ratio: 1 / 1;
  --game-card-media-bg: transparent;
  --game-card-media-frame-bg: transparent;
  --game-card-media-frame-border: transparent;
  --game-card-media-frame-shadow: none;
  --game-card-media-frame-padding: 0px;
  --game-card-media-radius: calc(var(--game-card-radius, 16px) - 5px);
  --game-card-media-inner-radius: var(--game-card-media-radius);
  --game-card-media-fit: cover;
  --game-title-glass-bg: linear-gradient(180deg, rgba(16,16,20,.18), rgba(16,16,20,.72));
  --game-title-glass-border: rgba(255,255,255,.12);
  --game-title-glass-shadow: none;
  --game-progress-height: 18px;
  --game-progress-height-mobile: 17px;
  --game-progress-value-inset: 6px;
  --rtpx-progress-track: #17181d;
  --rtpx-progress-low: #ef4444;
  --rtpx-progress-stable: #f97316;
  --rtpx-progress-medium: #facc15;
  --rtpx-progress-high: #22c55e;
  --game-card-shadow: none;
  --game-card-shadow-hover: none;
  --game-card-shadow-mobile: none;
  --game-card-backdrop: blur(18px) saturate(145%);
  --game-card-mobile-backdrop: none;

  /* Pattern preview */
  --material-glass-bg: rgba(16,16,20,.70);
  --material-glass-bg-soft: rgba(16,16,20,.44);
  --material-glass-bg-hover: rgba(255,255,255,.15);
  --material-glass-border: rgba(255,255,255,.10);
  --material-glass-border-strong: rgba(255,255,255,.15);
  --material-glass-blur: blur(18px) saturate(145%);
  --pola-preview-bg: linear-gradient(180deg, rgba(16,16,20,.54), rgba(16,16,20,.34));
  --pola-preview-border: var(--material-glass-border);
  --pola-preview-backdrop: var(--material-glass-blur);
  --pola-preview-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  --pola-preview-padding: 6px;
  --pola-preview-radius: 12px;
  --pola-preview-row-bg: rgba(255,255,255,.045);
  --pola-preview-row-border: rgba(255,255,255,.08);
  --pola-preview-row-radius: 9px;
  --pola-preview-row-min-height: 28px;
  --pola-preview-spin-size: 10.2px;
  --pola-preview-feature-size: 8.8px;

  /* Buttons and rail hover state */
  --interactive-soft-bg: rgba(255,255,255,.065);
  --interactive-soft-bg-hover: rgba(255,255,255,.10);
  --interactive-soft-border: rgba(255,255,255,.12);
  --interactive-soft-border-hover: rgba(255,255,255,.18);
  --carousel-control-size: clamp(44px, 3vw, 54px);
  --carousel-control-radius: 999px;
  --carousel-control-bg: rgba(255,255,255,.16);
  --carousel-control-bg-hover: rgba(255,255,255,.28);
  --carousel-control-color: #fff;
  --carousel-control-shadow: inset 0 1px 0 rgba(255,255,255,.12);
  --carousel-outline-idle: .625rem;
  --carousel-outline-active: .125rem;
  --content-card-radius: 1rem;
  --content-slider-gap: 1rem;
  --content-slider-peek: .2;
  --content-fade-mobile: 1rem;
  --content-fade-desktop: 1.35rem;

  /* Shadows and geometry */
  --shadow: 0 18px 54px rgba(0,0,0,.22);
  --shadow-soft: 0 10px 28px rgba(0,0,0,.16);
  --radius-xl: 30px;
  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --header-h: 74px;
  --shell: min(1440px, calc(100% - 32px));
  --focus-ring: 0 0 0 2px rgba(255,255,255,.16);
  --ui-transition-fast: .16s ease;
  --ui-transition-base: .24s ease;

  /* Toast */
  --toast-width: min(390px, calc(100vw - 28px));
  --toast-gap: 10px;
  --toast-offset: 18px;
  --toast-radius: 14px;
  --toast-bg: rgba(16,16,20,.92);
  --toast-border: rgba(255,255,255,.13);
  --toast-text: var(--text);
  --toast-description: rgba(248,248,250,.72);
  --toast-shadow: 0 18px 46px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
}

/* === typography.css === */
/* Global public typography layer: clean browser-native type system. */
html {
  font-family: var(--font-main);
  font-synthesis-weight: none;
  font-synthesis-style: none;
  font-kerning: normal;
  font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-main);
  font-size: var(--text-size-body);
  font-weight: var(--text-weight-body);
  line-height: var(--text-line-body);
  letter-spacing: var(--text-letter-ui);
  overflow-wrap: anywhere;
}

h1,
h2,
h3,
.section-title,
.jackpot-page-title,
.promo-hero-title,
.all-wins-title {
  font-family: var(--font-display);
  font-weight: var(--text-weight-display);
  line-height: var(--text-line-tight);
  letter-spacing: -.032em;
  text-wrap: balance;
}

p,
.section-kicker,
.section-subtitle,
.promo-hero-subtitle,
.all-wins-subtitle,
.footer-description {
  line-height: var(--text-line-body);
  text-wrap: pretty;
}

button,
input,
select,
textarea,
.nav-link,
.footer-link,
.catalog-tab,
.provider-filter-button,
.game-action,
.game-action-button,
.carousel-prev,
.carousel-next,
.jackpot-action,
.promo-button,
.admin-link-proxy {
  font-family: var(--font-main);
  font-weight: var(--text-weight-ui);
  line-height: var(--text-line-ui);
  letter-spacing: var(--text-letter-ui);
}

input,
select,
textarea {
  font-size: max(16px, var(--text-size-ui));
}

.section-kicker,
.pola-dialog-label,
.footer-heading,
.provider-chip,
.news-tag,
.news-date,
.age-badge,
.feature-provider-badge,
.feature-age-badge,
.creator-badge {
  font-size: var(--text-size-overline);
  font-weight: var(--text-weight-strong);
  line-height: 1.12;
  letter-spacing: var(--text-letter-overline);
  text-transform: uppercase;
}

.game-hover-title-text,
.game-title-link,
.feature-title-link,
.news-card-title,
.game-pola-name,
.game-pola-value,
.game-pola-preview-item strong,
.game-action,
.game-action-button,
.jackpot-card-title,
.win-card-title {
  font-family: var(--font-display);
  font-weight: var(--text-weight-strong);
  line-height: var(--text-line-tight);
  letter-spacing: var(--text-letter-tight);
}

.game-progress-value,
.admin-progress-theme-preview__text,
[data-numeric],
[data-progress-value],
.jp-value,
.wd-value {
  font-variant-numeric: tabular-nums lining-nums;
}

em,
i,
.text-italic,
[data-text-style="italic"] {
  font-family: var(--font-display-italic);
  font-style: italic;
}

::selection {
  color: var(--accent-contrast);
  background: color-mix(in srgb, var(--accent) 78%, #fff);
}

@media (max-width: 640px) {
  body {
    font-size: var(--text-size-body-mobile);
    line-height: 1.46;
    letter-spacing: 0;
  }

  h1,
  h2,
  h3,
  .section-title,
  .jackpot-page-title,
  .promo-hero-title,
  .all-wins-title {
    letter-spacing: -.026em;
  }

  .section-kicker,
  .provider-chip,
  .news-tag,
  .news-date,
  .age-badge,
  .feature-provider-badge,
  .feature-age-badge,
  .creator-badge {
    letter-spacing: .032em;
  }
}

/* === base.css === */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  min-width: 0;
  -webkit-tap-highlight-color: transparent;
}

html {
  min-height: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-h) + 16px);
  scrollbar-gutter: stable;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}


body {
  position: relative;
  min-width: 0;
  min-height: 100%;
  margin: 0;
  color: var(--text);
  font-family: var(--font-main);
  font-size: var(--text-size-body);
  font-weight: var(--text-weight-body);
  background: var(--theme-bg, #101014);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  overscroll-behavior-x: none;
}

body::before,
body::after {
  content: none;
}

body.modal-open {
  overflow: hidden;
}

img,
svg,
video,
canvas {
  display: block;
  max-width: 100%;
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

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

button,
input,
select {
  font: inherit;
}

button,
[type="button"],
[type="submit"],
[type="reset"] {
  appearance: none;
  border: 0;
  color: inherit;
  cursor: pointer;
  user-select: none;
  touch-action: manipulation;
}

button:disabled {
  cursor: not-allowed;
  opacity: .45;
}

input,
select {
  min-width: 0;
}

:focus-visible {
  outline: 0;
  box-shadow: var(--focus-ring);
}

.shell {
  width: var(--shell);
  margin-inline: auto;
}

.sr-only,
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  border: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.isHidden {
  opacity: 0;
  transform: translateY(8px);
}

.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
}


html.page-transition-out body {
  opacity: .72;
  transform: translate3d(0, 3px, 0);
  transition: opacity .09s ease, transform .09s ease;
}

@media (prefers-reduced-motion: reduce) {
  html.page-transition-out body {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* === layout.css === */
body {
  padding-top: var(--header-h);
}

main {
  min-height: calc(100vh - var(--header-h));
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(10px, 1.35vw, 18px);
  min-width: 0;
  margin-bottom: clamp(12px, 1.45vw, 18px);
}

.section-head > div,
.section-head p {
  min-width: 0;
}

.section-head p {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
}

.section-title-link {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-width: 0;
  gap: 0;
}

.section-title-link h2,
.section-head h2,
.catalog-head h2 {
  display: block;
  max-width: 100%;
  margin: 0;
  padding-block: .04em;
  overflow: visible;
  color: var(--text);
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.06;
  letter-spacing: -.045em;
  text-wrap: balance;
  overflow-wrap: anywhere;
}

.content-row-head {
  align-items: center;
  min-height: clamp(38px, 3.5vw, 54px);
}

.content-row-head .section-title-link,
.content-row-head > h2 {
  flex: 1 1 auto;
  min-width: 0;
}

.content-row-head .section-title-link h2,
.content-row-head > h2 {
  white-space: normal;
  text-overflow: unset;
}

.site-footer {
  padding: 34px 0 46px;
  color: var(--subtle);
}

.site-footer .shell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  border-top: 1px solid var(--line);
  padding-top: 22px;
}


/* Section heading rhythm. */
.section-head,
.content-row-head,
.news-head,
.catalog-head {
  min-height: clamp(42px, 4vw, 60px);
}

.section-title-link,
.content-row-head .section-title-link {
  min-height: 1.35em;
  overflow: visible;
}

.section-title-link h2,
.section-head h2,
.catalog-head h2,
.content-row-head .section-title-link h2,
.content-row-head > h2 {
  min-height: 1.18em;
  overflow: visible;
  text-wrap: balance;
  white-space: normal;
  word-break: normal;
  overflow-wrap: anywhere;
}

.section-action-link {
  flex: 0 0 auto;
  min-height: 34px;
  padding-inline: clamp(12px, 1.2vw, 18px);
  border-radius: 999rem;
  white-space: nowrap;
}

@media (max-width: 560px) {
  .section-head,
  .content-row-head,
  .news-head,
  .catalog-head {
    align-items: flex-start;
    gap: 8px;
  }

  .section-title-link h2,
  .section-head h2,
  .catalog-head h2,
  .content-row-head .section-title-link h2,
  .content-row-head > h2 {
    font-size: clamp(22px, 7.2vw, 30px);
    line-height: 1.1;
    letter-spacing: -.04em;
  }

  .section-action-link {
    min-height: 30px;
    padding-inline: 11px;
    font-size: 11px;
  }
}

/* === components.css === */
.button,
.link-button,
.detail-button,
.icon-button,
.sort-menu__button {
  min-height: 40px;
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  transition: transform .16s ease, border-color .16s ease, background-color .16s ease, color .16s ease;
}

.button,
.link-button,
.sort-menu__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding-inline: 16px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
  white-space: nowrap;
}

.button:hover,
.link-button:hover,
.sort-menu__button:hover {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  background: color-mix(in srgb, var(--surface) 28%, transparent);
  box-shadow: none;
}

.button.primary {
  color: var(--accent-contrast);
  border-color: color-mix(in srgb, var(--accent) 58%, transparent);
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: none;
}

.sort-menu__option.is-active {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  background: color-mix(in srgb, var(--text) 10%, transparent);
  box-shadow: none;
}

.button.ghost {
  background: var(--glass-bg);
}

.button {
  min-height: 44px;
  padding-inline: 18px;
}

.search__icon svg,
.icon-wrapper svg,
.carousel-next-icon svg,
.news-card-title svg {
  width: 1em;
  height: 1em;
  fill: currentColor;
}


.search-form {
  display: block;
  min-width: 0;
}

.search {
  position: relative;
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 36px;
  align-items: center;
  width: 100%;
  min-width: 230px;
  min-height: 42px;
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  overflow: hidden;
  isolation: isolate;
  transform: translateZ(0);
  transition: border-color .16s ease, background .16s ease, color .16s ease;
}

.search::before,
.search::after,
.search__submit::before,
.search__submit::after,
.search__close::before,
.search__close::after {
  content: none;
}

.search:focus-within,
.search:hover {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  background: color-mix(in srgb, var(--surface) 28%, transparent);
  box-shadow: none;
}

.search__input {
  position: relative;
  z-index: 1;
  grid-column: 2;
  grid-row: 1;
  width: 100%;
  min-width: 0;
  min-height: 40px;
  padding: 0 2px;
  border: 0;
  border-left: 0;
  border-right: 0;
  color: var(--text);
  background: transparent;
  box-shadow: none;
  outline: 0;
  appearance: none;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: -.01em;
}

.search__input::-webkit-search-decoration,
.search__input::-webkit-search-cancel-button {
  display: none;
}

.search__input::placeholder {
  color: color-mix(in srgb, var(--muted) 68%, transparent);
}

.search__submit,
.search__close {
  position: relative;
  z-index: 1;
  grid-row: 1;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  margin: 0;
  padding: 0;
  border: 0;
  border-left: 0;
  border-right: 0;
  border-radius: 999px;
  color: color-mix(in srgb, var(--muted) 78%, transparent);
  background: transparent;
  box-shadow: none;
  outline: 0;
  transition: color .16s ease, background-color .16s ease, opacity .16s ease, transform .16s ease;
}

.search__submit {
  grid-column: 1;
  justify-self: center;
}

.search__close {
  grid-column: 3;
  justify-self: center;
  opacity: 0;
  pointer-events: none;
}

.search.is-filled .search__close,
.search:focus-within .search__close {
  opacity: 1;
  pointer-events: auto;
}

.search__submit:hover,
.search__close:hover,
.search__submit:focus-visible,
.search__close:focus-visible {
  color: var(--text);
  background: color-mix(in srgb, var(--text) 9%, transparent);
  transform: scale(1.02);
}

.search__icon,
.icon-wrapper {
  display: grid;
  place-items: center;
}

.search__icon svg,
.search__close svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}

.sort-menu {
  position: relative;
  display: inline-flex;
}

.sort-menu__button::after {
  content: "";
  width: 7px;
  height: 7px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  transition: transform .16s ease;
}

.sort-menu[data-open="true"] .sort-menu__button::after {
  transform: translateY(2px) rotate(225deg);
}

.sort-menu__popover {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  left: auto;
  z-index: 90;
  display: grid;
  gap: 6px;
  width: min(220px, calc(100vw - 24px));
  max-height: min(280px, calc(100dvh - 132px));
  padding: 8px;
  border: 1px solid color-mix(in srgb, var(--text) 16%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface) 30%, transparent);
  box-shadow: none;
  backdrop-filter: blur(22px) saturate(150%);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overflow: auto;
  overscroll-behavior: contain;
  transform: translateY(6px) scale(.98);
  transform-origin: top right;
  transition: opacity .14s ease, visibility .14s ease, transform .14s ease;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--text) 28%, transparent) transparent;
}

.sort-menu[data-open="true"] .sort-menu__popover {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.sort-menu__option {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  min-height: 40px;
  padding: 0 13px;
  border-radius: 13px;
  color: var(--muted);
  background: transparent;
  font-size: 13px;
  font-weight: 850;
  text-align: left;
}

.sort-menu__option:hover,
.sort-menu__option:focus-visible {
  color: var(--text);
  background: color-mix(in srgb, var(--surface-3) 66%, transparent);
}

.sort-menu__popover::-webkit-scrollbar {
  width: 8px;
}

.sort-menu__popover::-webkit-scrollbar-thumb {
  border: 2px solid transparent;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 28%, transparent);
  background-clip: content-box;
}

.sort-native {
  position: absolute;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.carousel-stage {
  position: relative;
}

/* Carousel controls. */
.carousel-prev,
.carousel-next {
  position: absolute;
  z-index: 4;
  top: var(--control-y, 50%);
  display: grid;
  place-items: center;
  box-sizing: border-box;
  width: var(--carousel-control-size, 40px);
  height: var(--carousel-control-size, 40px);
  min-width: var(--carousel-control-size, 40px);
  min-height: var(--carousel-control-size, 40px);
  margin: 0;
  padding: 0;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: var(--carousel-control-radius, 7px);
  color: var(--carousel-control-color, #fff);
  background: var(--carousel-control-bg, rgba(255,255,255,.36));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), inset 0 -1px 0 rgba(0,0,0,.12);
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle, 0);
  outline-style: solid;
  outline-width: 0;
  opacity: .96;
  cursor: pointer;
  touch-action: manipulation;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transform: translate3d(0, -50%, 0);
  transition: opacity .15s ease-out, outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out, transform .15s ease-out, background-color .15s ease-out;
}

.carousel-prev:hover,
.carousel-next:hover,
.carousel-prev:focus-visible,
.carousel-next:focus-visible {
  opacity: 1;
  outline-color: rgba(255,255,255,.35);
  outline-offset: var(--carousel-outline-active, 2px);
  outline-width: var(--carousel-outline-active, 2px);
  background: var(--carousel-control-bg-hover, rgba(255,255,255,.48));
  transform: translate3d(0, -50%, 0) scale(1.025);
}

.carousel-prev:active,
.carousel-next:active {
  transform: translate3d(0, -50%, 0) scale(.985);
}

.carousel-prev {
  left: var(--control-inline, 8px);
}

.carousel-next {
  right: var(--control-inline, 8px);
}

.carousel-next-icon,
.carousel-control-icon {
  display: grid;
  place-items: center;
  width: clamp(17px, 1.25vw, 21px);
  height: clamp(17px, 1.25vw, 21px);
}

.carousel-next-icon svg,
.carousel-control-icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.slider-pagination,
.featured-slider-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: fit-content;
  max-width: min(300px, 60vw);
  margin: 12px auto 0;
  padding: 5px 8px;
  list-style: none;
  border: 1px solid color-mix(in srgb, var(--text) 11%, transparent);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.034)),
    color-mix(in srgb, var(--surface-solid) 44%, transparent);
  box-shadow: 0 1px 0 rgba(255,255,255,.09) inset, 0 10px 28px rgba(0,0,0,.16);
  backdrop-filter: blur(14px) saturate(135%);
  -webkit-backdrop-filter: blur(14px) saturate(135%);
}

.slider-pagination > * > *,
.featured-slider-pagination > * {
  flex: 0 0 auto;
  display: flex;
}

.slider-pagination button button,
.featured-slider-pagination button {
  position: relative;
  width: 15px;
  height: 4px;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 22%, transparent);
  overflow: hidden;
  opacity: .76;
  transition: width .18s ease, background-color .18s ease, opacity .18s ease;
}

.slider-pagination button[data-fnui-is-active="true"] button[data-fnui-is-active="true"],
.featured-slider-pagination button[data-fnui-is-active="true"],
.slider-pagination button._1dfuy4s2 button._1dfuy4s2,
.featured-slider-pagination button._1dfuy4s2 {
  width: 32px;
  opacity: 1;
  background: color-mix(in srgb, var(--text) 82%, var(--accent) 18%);
}

.category-strip {
  display: flex;
  flex-wrap: nowrap;
  gap: 9px;
  max-width: 100%;
  padding: 2px 2px 8px;
  margin-bottom: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  scrollbar-width: none;
}

.category-strip::-webkit-scrollbar,
.featured-rail::-webkit-scrollbar,
.content-row-rail::-webkit-scrollbar,
.news-rail::-webkit-scrollbar {
  display: none;
}

.category-chip,
.provider-chip {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: max-content;
  min-height: 34px;
  padding-inline: 15px;
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  white-space: nowrap;
  transition: border-color .16s ease, background-color .16s ease, color .16s ease;
}

.category-chip:hover,
.category-chip:focus-visible,
.provider-chip:hover,
.provider-chip:focus-visible {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  background: color-mix(in srgb, var(--surface) 28%, transparent);
  box-shadow: none;
}

.category-chip.is-active,
.provider-chip.is-active {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 46%, transparent);
  background: color-mix(in srgb, var(--text) 11%, transparent);
  box-shadow: none;
}

.catalog-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 34px;
  margin-bottom: 12px;
  color: var(--muted);
  font-size: 13px;
}

.link-button {
  min-height: 34px;
  padding-inline: 13px;
}

.dialog-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* Catalog controls */
.catalog-search-form {
  width: 100%;
  min-width: 0;
}

.sort-menu,
.sort-menu__button {
  width: 100%;
  min-width: 0;
}

.sort-menu__button {
  min-height: 44px;
  padding-inline: 14px;
  justify-content: center;
  text-align: center;
  border-color: color-mix(in srgb, var(--text) 18%, transparent);
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
}

.sort-menu__button::after {
  display: none;
}

.sort-menu__button > svg {
  display: none;
}

.catalog-status {
  justify-content: flex-start;
}

.catalog-status .link-button[hidden] {
  display: none;
}

/* Live Worker API catalog state */
.catalog-empty-state {
  flex: 1 0 100%;
  display: grid;
  place-items: center;
  min-height: 160px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  color: var(--muted);
  background: color-mix(in srgb, var(--surface) 86%, transparent);
  text-align: center;
}

.section-title-button {
  border: 0;
  padding: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}


.sort-menu__group-label {
  display: block;
  padding: 4px 9px 2px;
  color: var(--subtle);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  line-height: 1;
  text-transform: uppercase;
}

.sort-menu__divider {
  display: block;
  height: 1px;
  margin: 4px 2px;
  background: color-mix(in srgb, var(--text) 10%, transparent);
}

.provider-filter-strip {
  padding-top: 4px;
  padding-bottom: 8px;
}


.sort-menu__button span {
  display: block;
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-align: center;
  text-overflow: ellipsis;
}

/* MUI-like menu surface for all custom dropdown popovers */
.sort-menu__popover,
.simple-menu {
  padding: 4px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--text) 16%, transparent);
  color: #fff;
  background: color-mix(in srgb, var(--surface) 30%, transparent);
  background-image: none;
  box-shadow: none;
  backdrop-filter: blur(26px) saturate(150%);
  -webkit-backdrop-filter: blur(26px) saturate(150%);
  text-rendering: geometricprecision;
}

.sort-menu__option,
.simple-menu a,
.simple-menu button {
  min-height: 38px;
  border-radius: 10px;
  color: rgba(255,255,255,.86);
  background: transparent;
}

.sort-menu__option:hover,
.sort-menu__option:focus-visible,
.sort-menu__option.is-active,
.simple-menu a:hover,
.simple-menu a:focus-visible,
.simple-menu button:hover,
.simple-menu button:focus-visible {
  color: #fff;
  background: rgba(255,255,255,.075);
  outline: 0;
}

/* === toast.css === */
/*
  Lightweight global toast layer.
  Adaptasi bersih dari referensi Sonner: stacked fixed messages, rich states,
  dark glass surface, mobile-safe offset, dan reduced-motion friendly.
*/
[data-rtpx-toaster] {
  position: fixed;
  right: var(--toast-offset, 18px);
  bottom: var(--toast-offset, 18px);
  z-index: 999999;
  display: grid;
  gap: var(--toast-gap, 10px);
  width: var(--toast-width, min(390px, calc(100vw - 28px)));
  max-width: calc(100vw - 28px);
  margin: 0;
  padding: 0;
  pointer-events: none;
  list-style: none;
}

[data-rtpx-toast] {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: 10px;
  width: 100%;
  min-height: 54px;
  padding: 14px 13px;
  border: 1px solid var(--toast-border, rgba(255,255,255,.13));
  border-radius: var(--toast-radius, 14px);
  color: var(--toast-text, var(--text));
  background: var(--toast-bg, rgba(17,22,32,.92));
  box-shadow: var(--toast-shadow, 0 18px 46px rgba(0,0,0,.34));
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  pointer-events: auto;
  overflow: hidden;
  overflow-wrap: anywhere;
  opacity: 0;
  transform: translate3d(0, 12px, 0) scale(.985);
  transition: opacity .24s ease, transform .24s ease, border-color .18s ease, background .18s ease;
}

[data-rtpx-toast][data-mounted="true"] {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

[data-rtpx-toast][data-removing="true"] {
  opacity: 0;
  transform: translate3d(0, 10px, 0) scale(.985);
}

.rtpx-toast-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 34%, transparent);
}

.rtpx-toast-icon::before {
  content: "";
  display: block;
  width: 7px;
  height: 7px;
  border-radius: inherit;
  background: var(--accent);
  box-shadow: 0 0 14px color-mix(in srgb, var(--accent) 54%, transparent);
}

.rtpx-toast-content {
  display: grid;
  gap: 3px;
  min-width: 0;
}

.rtpx-toast-title {
  color: inherit;
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 900;
  line-height: 1.22;
  letter-spacing: -.01em;
}

.rtpx-toast-description {
  color: var(--toast-description, rgba(245,247,251,.72));
  font-size: 12px;
  font-weight: 620;
  line-height: 1.42;
}

.rtpx-toast-close {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  margin-top: -2px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 999px;
  color: rgba(255,255,255,.76);
  background: rgba(255,255,255,.06);
  font-size: 17px;
  line-height: 1;
  transition: background .16s ease, border-color .16s ease, color .16s ease;
}

.rtpx-toast-close:hover,
.rtpx-toast-close:focus-visible {
  color: #fff;
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
}

[data-rtpx-toast][data-type="success"] .rtpx-toast-icon { background: color-mix(in srgb, var(--good) 18%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--good) 34%, transparent); }
[data-rtpx-toast][data-type="success"] .rtpx-toast-icon::before { background: var(--good); box-shadow: 0 0 14px color-mix(in srgb, var(--good) 54%, transparent); }
[data-rtpx-toast][data-type="warning"] .rtpx-toast-icon { background: color-mix(in srgb, var(--warn) 18%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--warn) 34%, transparent); }
[data-rtpx-toast][data-type="warning"] .rtpx-toast-icon::before { background: var(--warn); box-shadow: 0 0 14px color-mix(in srgb, var(--warn) 54%, transparent); }
[data-rtpx-toast][data-type="error"] .rtpx-toast-icon { background: color-mix(in srgb, var(--danger) 18%, transparent); box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--danger) 34%, transparent); }
[data-rtpx-toast][data-type="error"] .rtpx-toast-icon::before { background: var(--danger); box-shadow: 0 0 14px color-mix(in srgb, var(--danger) 54%, transparent); }

@media (max-width: 600px) {
  [data-rtpx-toaster] {
    left: 14px;
    right: 14px;
    bottom: calc(14px + env(safe-area-inset-bottom));
    width: auto;
    max-width: none;
  }

  [data-rtpx-toast] {
    padding: 13px 12px;
  }
}

@media (prefers-reduced-motion: reduce) {
  [data-rtpx-toast] {
    transition: none;
    transform: none;
  }
}

/* === loading-overlay.css === */
/* ===== loading-overlay.css ===== */
.rtpx-loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  display: grid;
  place-items: center;
  width: 100%;
  min-width: 100vw;
  height: 100vh;
  min-height: 100vh;
  min-height: 100svh;
  min-height: 100dvh;
  padding:
    max(14px, env(safe-area-inset-top))
    max(14px, env(safe-area-inset-right))
    max(14px, env(safe-area-inset-bottom))
    max(14px, env(safe-area-inset-left));
  margin: 0;
  overflow: hidden;
  overscroll-behavior: contain;
  background: rgba(8, 10, 14, .46);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  contain: strict;
  transform: translate3d(0, 0, 0);
  transition: opacity .14s ease, visibility 0s linear .14s;
}

.rtpx-loading-overlay.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity .14s ease, visibility 0s linear 0s;
}

.rtpx-loading-overlay.is-non-blocking {
  pointer-events: none;
}

.rtpx-loading-overlay__panel {
  position: relative;
  display: grid;
  place-items: center;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  transform: translate3d(0, 0, 0) scale(.985);
  transition: transform .14s ease;
}

.rtpx-loading-overlay.is-visible .rtpx-loading-overlay__panel {
  transform: translate3d(0, 0, 0) scale(1);
}

.rtpx-loading-overlay__spinner {
  width: clamp(28px, 7vw, 34px);
  height: clamp(28px, 7vw, 34px);
  display: block;
  border-radius: 999px;
  border: 2.5px solid rgba(255,255,255,.18);
  border-top-color: rgba(255,255,255,.98);
  border-right-color: rgba(255,255,255,.72);
  background: transparent;
  filter: drop-shadow(0 0 10px rgba(255,255,255,.16));
  animation: rtpx-loading-spin .74s linear infinite;
  will-change: transform;
}

.rtpx-loading-overlay__label,
.rtpx-loading-overlay [data-loading-label] {
  display: none !important;
}

html[data-loading-overlay="true"] body {
  cursor: progress;
}

@keyframes rtpx-loading-spin {
  to { transform: rotate(360deg); }
}

@media (max-width: 640px) {
  .rtpx-loading-overlay {
    background: rgba(8, 10, 14, .50);
  }

  .rtpx-loading-overlay__panel {
    width: auto;
    height: auto;
    box-shadow: none;
  }

  .rtpx-loading-overlay__spinner {
    width: 30px;
    height: 30px;
    border-width: 2.25px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .rtpx-loading-overlay,
  .rtpx-loading-overlay__panel {
    transition: none;
  }

  .rtpx-loading-overlay__spinner {
    animation-duration: 1.4s;
  }
}

/* === sections.css === */
.eyebrow {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 25px;
  padding-inline: 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  background: var(--glass-bg);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .08) inset;
  font-size: 10.5px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  backdrop-filter: blur(12px) saturate(134%);
  -webkit-backdrop-filter: blur(12px) saturate(134%);
}

.discovery-sections,
.featured,
.news-section,
.catalog {
  padding-block: clamp(12px, 1.55vw, 22px);
  background-color: transparent;
  overflow: visible;
}

.news-section {
  overflow-anchor: none;
}

.news-section[data-news-loading] {
  display: block;
  min-height: clamp(260px, 24vw, 430px);
}

.news-section[data-news-loading] .news-rail {
  min-height: clamp(214px, 20vw, 340px);
}

.content-row {
  position: relative;
  width: 100%;
  margin-bottom: clamp(16px, 1.8vw, 28px);
  overflow: visible;
  isolation: isolate;
}

.content-row:last-child {
  margin-bottom: 0;
}

.content-row-head {
  margin-bottom: clamp(6px, .8vw, 12px);
}

.content-row-stage {
  --content-row-control-y: var(--rail-control-fallback-y, 72px);
  --control-y: var(--content-row-control-y);
  --control-inline: 0px;
  --fn-slider--slides-in-view: 6;
  --game-card-gap: clamp(12px, 1.05vw, 16px);
  --featured-card-gap: var(--game-card-gap);
  --catalog-card-width: clamp(176px, 12vw, 196px);
  --featured-card-width: var(--catalog-card-width);
  position: relative;
  overflow: visible;
  contain: layout;
}

.featured-carousel-stage {
  --control-y: var(--featured-control-y, 72px);
  --control-inline: 0px;
  --fn-slider--slides-in-view: 6;
  --game-card-gap: clamp(12px, 1.05vw, 16px);
  --featured-card-gap: var(--game-card-gap);
  --catalog-card-width: clamp(176px, 12vw, 196px);
  --featured-card-width: var(--catalog-card-width);
}

.featured-rail,
.content-row-rail,
.news-rail {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  overscroll-behavior-x: contain;
}

.featured-rail.is-dragging,
.content-row-rail.is-dragging,
.news-rail.is-dragging.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
}

.featured-rail,
.content-row-rail {
  --rail-hover-safe: 16px;
  gap: var(--featured-card-gap);
  padding: 12px var(--featured-edge-fade, 18px) 18px var(--rail-hover-safe);
  margin-left: calc(-1 * var(--rail-hover-safe));
}

.feature-island-card {
  display: grid;
  grid-template-rows: auto minmax(30px, auto) auto auto auto;
  align-content: start;
  flex: 0 0 var(--featured-card-width, 196px);
  width: var(--featured-card-width, 196px);
  min-width: var(--featured-card-width, 196px);
  max-width: var(--featured-card-width, 196px);
  scroll-snap-align: start;
  border-radius: var(--game-card-radius, 16px);
  transition: transform .16s ease, opacity .16s ease;
}

.feature-card-hit,
.game-card-hit {
  position: relative;
  display: block;
  width: 100%;
  padding: 0;
  border-radius: var(--game-card-radius, 16px);
  background: transparent;
  text-align: inherit;
}

.feature-cover,
.game-cover {
  position: relative;
  display: block;
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
  overflow: hidden;
  border: 0;
  border-radius: var(--game-card-media-radius, calc(var(--game-card-radius, 16px) - 5px));
  background: transparent;
  box-shadow: none;
  isolation: isolate;
}

.feature-cover img,
.game-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .18s ease;
}

.game-hover-title {
  position: absolute;
  inset: auto 7px 7px;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--game-title-glass-border, rgba(255,255,255,.14));
  border-radius: 12px;
  color: var(--text);
  background: var(--game-title-glass-bg, rgba(10,16,28,.72));
  box-shadow: var(--game-title-glass-shadow, 0 8px 18px rgba(0,0,0,.22));
  backdrop-filter: blur(12px) saturate(145%);
  -webkit-backdrop-filter: blur(12px) saturate(145%);
  opacity: 0;
  pointer-events: none;
  text-decoration: none;
  transform: translate3d(0, calc(100% + 10px), 0);
  transition: opacity .16s ease, transform .16s ease, border-color .16s ease, background .16s ease;
}

.game-hover-title-text {
  display: -webkit-box;
  max-width: 100%;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: inherit;
  font-size: clamp(12px, .78vw, 13.5px);
  font-weight: var(--text-weight-strong);
  line-height: 1.16;
  letter-spacing: -.008em;
  overflow-wrap: anywhere;
  text-align: center;
  text-shadow: 0 1px 2px rgba(0,0,0,.34);
}

.game-card:hover .game-hover-title,
.game-card:focus-within .game-hover-title,
.game-hover-title:focus-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
}

.feature-island-card:hover .feature-cover img,
.game-card:hover .game-cover img,
.news-card:hover img {
  transform: translateZ(0) scale(1.018);
}

.feature-top-overlay,
.game-overlay {
  position: absolute;
  inset: 8px 8px auto;
  display: flex;
  justify-content: space-between;
  gap: 8px;
  pointer-events: none;
}

.feature-provider-badge,
.feature-age-badge,
.creator-badge,
.age-badge,
.island-code,
.news-tag,
.news-date {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 25px;
  padding-inline: 9px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: #fff;
  background: rgba(0,0,0,.52);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.creator-badge,
.feature-provider-badge {
  justify-content: flex-start;
  max-width: calc(100% - 52px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.game-overlay--single {
  inset: 7px auto auto 7px;
  justify-content: flex-start;
}

.game-overlay--single .age-badge {
  max-width: calc(100% - 14px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.feature-title-wrap,
.game-title-wrap {
  display: none;
}

.feature-title-link,
.game-title-link,
.news-card-title {
  color: var(--text);
  font-size: clamp(12.5px, .78vw, 14px);
  font-weight: 900;
  line-height: 1.14;
  letter-spacing: -.01em;
  overflow-wrap: anywhere;
}

.feature-title-link,
.game-title-link {
  display: -webkit-box;
  min-height: 30px;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.island-code {
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-3) 84%, transparent);
}

.news-carousel-stage {
  --control-y: var(--news-control-y, 50%);
  --control-inline: 0px;
}

.news-rail {
  gap: 16px;
  padding: 12px 18px 18px var(--rail-hover-safe, 8px);
  margin-left: calc(-1 * var(--rail-hover-safe, 8px));
}

.news-card {
  flex: 0 0 clamp(272px, 31vw, 360px);
  width: clamp(272px, 31vw, 360px);
  scroll-snap-align: start;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--glass-bg);
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
  overflow: hidden;
  transition: transform .16s ease, border-color .16s ease, opacity .16s ease;
}

.news-card-media {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--surface-2);
}

.news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.news-card-body {
  display: grid;
  gap: 11px;
  padding: 14px;
}

.news-date,
.news-tag {
  justify-self: start;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-3) 84%, transparent);
}

.news-card-title {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 10px;
  min-height: 48px;
}

.news-card-title svg {
  width: 18px;
  height: 18px;
  color: var(--accent);
}

.catalog-head {
  align-items: center;
}

.toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(126px, 152px);
  align-items: center;
  gap: 10px;
  width: min(620px, 100%);
  margin-left: auto;
}

.catalog-search-form {
  min-width: 0;
}

.game-card {
  display: block;
  flex: 0 0 var(--catalog-card-width, var(--featured-card-width, 196px));
  width: var(--catalog-card-width, var(--featured-card-width, 196px));
  min-width: var(--catalog-card-width, var(--featured-card-width, 196px));
  max-width: var(--catalog-card-width, var(--featured-card-width, 196px));
  scroll-snap-align: start;
  border-radius: var(--game-card-radius, 16px);
  transition: transform .16s ease, opacity .16s ease;
}

.game-card-shell {
  box-sizing: border-box;
  display: grid;
  grid-template-rows: auto minmax(30px, auto) auto auto auto;
  align-content: start;
  width: 100%;
  min-width: 0;
  padding: 7px;
  border: 1px solid var(--game-card-border);
  border-radius: var(--game-card-radius, 16px);
  color: var(--game-card-text);
  background-color: var(--game-card-bg);
  background-image: none;
  box-shadow:
    var(--game-card-shadow);
  overflow: hidden;
  isolation: isolate;
  backdrop-filter: var(--game-card-backdrop);
  -webkit-backdrop-filter: var(--game-card-backdrop);
  transition: transform .16s ease, border-color .16s ease, background-color .16s ease, box-shadow .16s ease;
}

.game-card:hover,
.feature-island-card:hover,
.news-card:hover {
  transform: translate3d(0, -2px, 0);
}

.game-card:hover .game-card-shell,
.game-card:focus-within .game-card-shell {
  border-color: var(--game-card-border-hover);
  background-color: var(--game-card-bg-hover);
  box-shadow:
    var(--game-card-shadow-hover);
}

.game-cover {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
}

.feature-cover,
.game-cover {
  border-color: transparent;
  border-radius: var(--game-card-media-radius, calc(var(--game-card-radius, 16px) - 5px));
  background: transparent;
  box-shadow: none;
}

.game-progress {
  display: block;
  margin-top: 9px;
  padding-inline: 2px;
  contain: layout paint style;
}

.game-progress-row,
.game-progress-label {
  display: none;
}

.game-progress-track {
  position: relative;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  min-height: var(--game-progress-height, 18px);
  padding-inline: var(--game-progress-value-inset, 6px);
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--rtpx-progress-low, #ef4444) 18%, rgba(255,255,255,.10));
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,0) 46%),
    linear-gradient(90deg, color-mix(in srgb, var(--rtpx-progress-track, #17181d) 92%, #06070a), color-mix(in srgb, var(--rtpx-progress-track, #17181d) 76%, rgba(255,255,255,.10)));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    inset 0 -1px 0 rgba(0,0,0,.30),
    0 6px 14px rgba(0,0,0,.14);
  isolation: isolate;
}

.game-progress-track::before,
.game-progress-track::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-radius: inherit;
}

.game-progress-track::before {
  inset: 2px;
  z-index: 2;
  border: 1px solid rgba(255,255,255,.055);
}

.game-progress-track::after {
  inset: 0;
  z-index: 3;
  background: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0) 42%);
  opacity: .42;
}

.game-progress-fill {
  position: absolute;
  inset: 0 auto 0 0;
  z-index: 1;
  width: var(--game-progress, 0%);
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  border-radius: inherit;
  background:
    linear-gradient(90deg,
      var(--rtpx-progress-low, #ef4444) 0%,
      color-mix(in srgb, var(--rtpx-progress-low, #ef4444) 35%, var(--rtpx-progress-stable, #f97316)) 28%,
      var(--rtpx-progress-stable, #f97316) 46%,
      var(--rtpx-progress-medium, #facc15) 72%,
      var(--rtpx-progress-high, #22c55e) 100%);
  background-size: var(--game-progress-bg-size, 100%) 100%;
  background-position: left center;
  background-repeat: no-repeat;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.26),
    inset 0 -1px 0 rgba(0,0,0,.22),
    0 0 10px color-mix(in srgb, var(--rtpx-progress-medium, #facc15) 26%, transparent);
}

.game-progress-fill::before,
.game-progress-fill::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
}

.game-progress-fill::before {
  background: repeating-linear-gradient(135deg, rgba(255,255,255,.20) 0 5px, rgba(255,255,255,0) 5px 11px);
  opacity: .23;
}

.game-progress-fill::after {
  background: linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,0) 48%);
  opacity: .42;
}

.game-progress-value {
  position: relative;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  margin-left: auto;
  padding: 3px 5px 2px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  color: #fff;
  background: rgba(4,10,18,.58);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09);
  font-size: 10.8px;
  font-weight: var(--text-weight-strong);
  line-height: 1;
  letter-spacing: .006em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 1px 2px rgba(0,0,0,.55);
}

.game-progress[data-progress-tier="low"] .game-progress-fill,
.game-progress[data-progress-tier="stable"] .game-progress-fill {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.24),
    inset 0 -1px 0 rgba(0,0,0,.24),
    0 0 9px color-mix(in srgb, var(--rtpx-progress-low, #ef4444) 24%, transparent);
}

.game-progress[data-progress-tier="medium"] .game-progress-fill {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.25),
    inset 0 -1px 0 rgba(0,0,0,.23),
    0 0 10px color-mix(in srgb, var(--rtpx-progress-stable, #f97316) 25%, transparent);
}

.game-progress[data-progress-tier="high"] .game-progress-fill {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.26),
    inset 0 -1px 0 rgba(0,0,0,.22),
    0 0 11px color-mix(in srgb, var(--rtpx-progress-medium, #facc15) 25%, transparent);
}

.game-progress[data-progress-tier="max"] .game-progress-fill {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.28),
    inset 0 -1px 0 rgba(0,0,0,.22),
    0 0 12px color-mix(in srgb, var(--rtpx-progress-high, #22c55e) 28%, transparent);
}
.game-pola-preview {
  display: block;
  margin-top: 10px;
  padding: var(--pola-preview-padding, 8px);
  border: 1px solid var(--pola-preview-border, rgba(255,255,255,.10));
  border-radius: var(--pola-preview-radius, 12px);
  color: var(--game-card-text, #fff);
  background: var(--pola-preview-bg, rgba(16,16,20,.38));
  min-height: var(--pola-preview-stable-height, 124px);
  box-shadow: var(--pola-preview-shadow, inset 0 1px 0 rgba(255,255,255,.08));
  overflow: hidden;
  contain: layout paint style;
}

@supports ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .game-pola-preview {
    backdrop-filter: var(--pola-preview-backdrop, blur(14px) saturate(135%));
    -webkit-backdrop-filter: var(--pola-preview-backdrop, blur(14px) saturate(135%));
  }
}

.game-pola-preview-head,
.game-pola-preview-badge,
.game-pola-preview-label {
  display: none;
}

.game-pola-preview-list {
  display: grid;
  gap: 5px;
}

.game-pola-preview-item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: var(--pola-preview-row-min-height, 34px);
  padding: 5px 6px;
  border: 1px solid var(--pola-preview-row-border, rgba(255,255,255,.08));
  border-radius: var(--pola-preview-row-radius, 9px);
  background: var(--pola-preview-row-bg, rgba(255,255,255,.045));
}

.game-pola-preview-copy {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  align-items: center;
  gap: 2px;
  width: 100%;
  min-width: 0;
  text-align: center;
}

.game-pola-preview-item strong,
.game-pola-preview-item small,
.game-pola-preview-spin,
.game-pola-preview-feature {
  display: block;
  max-width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
}

.game-pola-preview-item strong,
.game-pola-preview-spin {
  order: 2;
  color: rgba(255,255,255,.94);
  font-size: var(--pola-preview-spin-size, 10.8px);
  font-weight: var(--text-weight-strong);
  line-height: 1.05;
  letter-spacing: .015em;
  text-transform: uppercase;
}

.game-pola-preview-item small,
.game-pola-preview-feature {
  order: 1;
  color: rgba(255,255,255,.62);
  font-size: var(--pola-preview-feature-size, 9.4px);
  font-weight: var(--text-weight-ui);
  line-height: 1.05;
}

.game-pola-preview-empty {
  display: grid;
  place-items: center;
  min-height: 42px;
  padding: 8px;
  border: 1px dashed rgba(255,255,255,.11);
  border-radius: var(--pola-preview-row-radius, 9px);
  color: rgba(255,255,255,.62);
  background: rgba(255,255,255,.035);
  font-size: 10.5px;
  font-weight: var(--text-weight-ui);
  text-align: center;
}

.game-pola-preview.is-loading .game-pola-preview-empty {
  color: rgba(255,255,255,.62);
}

.game-card-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  margin-top: 8px;
  padding-inline: 0;
}

.game-action-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  min-height: 30px;
  padding: 0 11px;
  border: 1px solid var(--interactive-soft-border);
  border-radius: 10px;
  color: rgba(255,255,255,.86);
  background: var(--interactive-soft-bg);
  box-shadow: none;
  cursor: pointer;
  font: inherit;
  font-size: 11.2px;
  font-weight: var(--text-weight-strong);
  line-height: 1.05;
  letter-spacing: .025em;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  transition: transform .14s ease, border-color .14s ease, background-color .14s ease, color .14s ease, opacity .14s ease;
}

.game-action-pola,
.game-action-main {
  color: rgba(255,255,255,.86);
  background: var(--interactive-soft-bg);
  border-color: var(--interactive-soft-border);
  box-shadow: none;
}

.game-action-button:hover,
.game-action-button:focus-visible,
.game-action-main:hover,
.game-action-main:focus-visible {
  color: #fff;
  border-color: var(--interactive-soft-border-hover);
  background: var(--interactive-soft-bg-hover);
  outline: none;
  transform: translate3d(0, -1px, 0);
  box-shadow: none;
}

.game-action-button:active {
  transform: translate3d(0, 0, 0);
}

.game-action-button[aria-disabled="true"],
.game-action-button.is-disabled {
  pointer-events: none;
  opacity: .45;
}

.game-dialog {
  width: min(960px, calc(100vw - 28px));
  max-height: min(720px, calc(100dvh - 28px));
  padding: 0;
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-xl);
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 78%, transparent);
  box-shadow: var(--shadow);
  overflow: hidden;
  backdrop-filter: blur(22px) saturate(165%);
  -webkit-backdrop-filter: blur(22px) saturate(165%);
}

.game-dialog::backdrop {
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.dialog-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(300px, .95fr);
  max-height: min(720px, calc(100dvh - 28px));
  overflow: auto;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--text) 25%, transparent) transparent;
}

.dialog-card::-webkit-scrollbar {
  width: 8px;
}

.dialog-card::-webkit-scrollbar-thumb {
  border: 2px solid transparent;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text) 26%, transparent);
  background-clip: content-box;
}

.dialog-card > img {
  width: 100%;
  height: 100%;
  min-height: 480px;
  object-fit: cover;
  background: var(--surface-2);
}

.dialog-body {
  display: grid;
  align-content: center;
  gap: 16px;
  padding: clamp(24px, 4vw, 38px);
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 78%, transparent), color-mix(in srgb, var(--surface-2) 72%, transparent));
}

.dialog-body h3 {
  margin: 0;
  font-size: clamp(30px, 4vw, 52px);
  line-height: .96;
  letter-spacing: -.055em;
}

.dialog-body dl {
  display: grid;
  gap: 9px;
  margin: 0;
}

.dialog-body dl div {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--surface-3) 48%, transparent);
}

.dialog-body dt {
  color: var(--muted);
}

.dialog-body dd {
  margin: 0;
  font-weight: 900;
  text-align: right;
}

.dialog-close {
  position: absolute;
  top: 14px;
  right: 14px;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 999px;
  color: rgba(245, 247, 251, .88);
  background: rgba(10, 15, 24, .82);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 28px rgba(0,0,0,.24);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-size: 22px;
  line-height: 1;
}

.dialog-close svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
  pointer-events: none;
}

.dialog-close:hover,
.dialog-close:focus-visible {
  color: var(--accent-contrast);
  background: color-mix(in srgb, var(--accent) 82%, white 10%);
  border-color: color-mix(in srgb, var(--accent) 46%, white 12%);
  outline: none;
}

.game-dialog.is-pattern-mode {
  width: min(520px, calc(100vw - 28px));
}

.game-dialog.is-pattern-mode .dialog-card {
  grid-template-columns: minmax(0, 1fr);
}

.game-dialog.is-pattern-mode .dialog-card > img {
  display: none;
}

.game-dialog.is-pattern-mode .dialog-body {
  min-height: auto;
  align-content: start;
  gap: 14px;
  padding: clamp(20px, 3.2vw, 30px);
}

.game-dialog.is-pattern-mode .dialog-body dl {
  display: none;
}

.dialog-patterns {
  display: grid;
  gap: 10px;
}

.dialog-patterns[hidden] {
  display: none;
}

.dialog-patterns-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: color-mix(in srgb, var(--muted) 88%, transparent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
}

.dialog-patterns-head strong {
  color: rgba(255,255,255,.90);
  font-variant-numeric: tabular-nums;
}

.dialog-pattern-list {
  display: grid;
  gap: 8px;
}

.dialog-pattern-item {
  display: grid;
  grid-template-columns: minmax(68px, .72fr) minmax(0, 1.28fr);
  align-items: center;
  gap: 3px 12px;
  padding: 12px 14px;
  border: 1px solid var(--game-card-border);
  border-radius: 16px;
  background: var(--interactive-soft-bg);
}

.dialog-pattern-label,
.dialog-pattern-item small {
  color: rgba(255,255,255,.62);
  font-size: 11px;
  font-weight: 850;
}

.dialog-pattern-item strong {
  color: rgba(255,255,255,.90);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .02em;
  text-align: right;
  white-space: nowrap;
}

.dialog-pattern-item small {
  grid-column: 1 / -1;
}

.catalog-control-panel {
  position: relative;
  z-index: 5;
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.catalog-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  margin: 0;
}

.catalog-controls .toolbar {
  width: min(620px, 100%);
  margin-left: auto;
}

.catalog-control-panel .category-strip {
  margin: 0;
}

.catalog-control-panel .catalog-status {
  min-height: 24px;
  margin: 0;
}

.catalog-control-section {
  padding-block: clamp(2px, .45vw, 8px) clamp(6px, .75vw, 12px);
}

.discovery-sections--rest {
  padding-block-start: clamp(2px, .45vw, 8px);
}

.discovery-sections--rest .content-row:first-child {
  margin-top: 0;
}

.catalog-control-panel .category-strip {
  display: flex;
  flex-wrap: nowrap;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  white-space: nowrap;
  touch-action: pan-x;
  scrollbar-width: none;
}

.catalog-control-panel .category-chip {
  flex: 0 0 auto;
  white-space: nowrap;
}

/* Stable API rail sizing: prevents card collapse at extreme browser zoom and keeps horizontal rails from exposing the entire dataset. */
.api-content-stage {
  --catalog-card-width: var(--catalog-card-width, 196px);
  max-width: 100%;
}

.api-content-stage .content-row-rail {
  min-width: 0;
  max-width: 100%;
  flex-wrap: nowrap;
}

.api-content-stage .game-card {
  flex-shrink: 0;
  contain: layout style;
}

.game-cover,
.feature-cover {
  transform: translateZ(0);
  backface-visibility: hidden;
}

.game-cover img,
.feature-cover img {
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* Rail edge and control alignment now lives in rail-edge.css and carousel.js. */

.provider-empty-state {
  display: grid;
  place-items: center;
  min-height: clamp(180px, 32vw, 320px);
  padding: clamp(26px, 5vw, 56px) 16px;
  text-align: center;
}

.provider-empty-state p {
  margin: 0;
  color: var(--muted);
  font-size: clamp(15px, 2.2vw, 20px);
  font-weight: 850;
  letter-spacing: -.01em;
}

.dialog-pattern-detail {
  display: grid;
  gap: 10px;
  margin-top: 2px;
  padding: 12px;
  border: 1px solid var(--game-card-border);
  border-radius: 18px;
  background: rgba(255,255,255,.045);
  box-shadow: none;
}

.dialog-pattern-detail-title {
  color: rgba(255,255,255,.86);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.dialog-pattern-detail-grid {
  display: grid;
  gap: 8px;
}

.dialog-pattern-section {
  display: grid;
  gap: 7px;
  min-width: 0;
  padding: 9px;
  border: 1px solid var(--game-card-border);
  border-radius: 15px;
  background: rgba(255,255,255,.04);
}

.dialog-pattern-section-title {
  color: rgba(255,255,255,.76);
  font-size: 10.5px;
  font-weight: 950;
  letter-spacing: .035em;
  text-transform: uppercase;
}

.dialog-pattern-section-rows {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.dialog-pattern-detail-row {
  display: grid;
  grid-template-columns: minmax(68px, .72fr) minmax(0, 1.28fr);
  align-items: center;
  gap: 8px;
  min-height: 32px;
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 13px;
  background: var(--game-card-media-bg);
}

.dialog-pattern-detail-row span {
  min-width: 0;
  overflow: hidden;
  color: rgba(255,255,255,.62);
  font-size: 10.5px;
  font-weight: 850;
  line-height: 1.16;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dialog-pattern-detail-row strong {
  min-width: 0;
  color: rgba(255,255,255,.90);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .01em;
  line-height: 1.16;
  text-align: right;
  overflow-wrap: anywhere;
}

.dialog-pattern-detail-row--pattern strong {
  color: rgba(255,255,255,.90);
}

.dialog-pattern-lines {
  display: none;
}

.dialog-pattern-gap {
  height: 4px;
}

.dialog-pattern-note {
  padding: 11px 13px;
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 14px;
  color: color-mix(in srgb, var(--muted) 86%, transparent);
  background: color-mix(in srgb, var(--surface-solid) 38%, transparent);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
}

.dialog-pattern-note--empty {
  display: grid;
  place-items: center;
  min-height: 74px;
  text-align: center;
}

/* Invisible media lock: keeps image area equal without drawing an extra frame inside the card. */
.game-card .game-card-media-shell,
.game-card .game-card-hit {
  background: transparent;
  border: 0;
  box-shadow: none;
  outline: 0;
}

.game-card .feature-cover,
.game-card .game-cover,
.game-card .game-cover-frame {
  box-sizing: border-box;
  padding: 0;
  border: 0;
  border-radius: var(--game-card-media-radius, calc(var(--game-card-radius, 16px) - 5px));
  background: transparent;
  box-shadow: none;
  outline: 0;
  overflow: hidden;
}

.game-card .game-cover img,
.game-card .game-cover-frame img,
.game-card .feature-cover img {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  border-radius: var(--game-card-media-inner-radius, var(--game-card-media-radius, 8px));
  background: transparent;
  box-shadow: none;
  object-fit: var(--game-card-media-fit, cover);
}

@media (pointer: fine) {
  .game-card:hover .game-card-shell,
  .game-card:focus-within .game-card-shell {
    outline-color: rgba(255,255,255,.20);
    outline-offset: 2px;
    outline-width: 1px;
  }

  .game-card:hover .game-cover,
  .game-card:focus-within .game-cover,
  .game-card:hover .game-cover-frame,
  .game-card:focus-within .game-cover-frame {
    outline: 0;
    transform: none;
  }
}

/* Card interaction aligned with rail navigation glass buttons. */
.game-card,
.feature-island-card.game-card {
  touch-action: manipulation;
}

.game-card-shell {
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle, .625rem);
  outline-style: solid;
  outline-width: 0;
}

.game-card:hover,
.feature-island-card.game-card:hover,
.news-card:hover {
  transform: none;
}

.game-card:hover .game-card-shell,
.game-card:focus-within .game-card-shell,
.feature-island-card.game-card:hover .game-card-shell,
.feature-island-card.game-card:focus-within .game-card-shell {
  border-color: var(--game-card-border-hover);
  background-color: var(--game-card-bg-hover);
  outline-color: var(--game-card-outline);
  outline-offset: var(--carousel-outline-active, .1875rem);
  outline-width: var(--carousel-outline-active, .1875rem);
  transform: translate3d(0, -1px, 0) scale(1.01);
  box-shadow: var(--carousel-control-shadow, 0 6px 16px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.16));
}

.game-card:active .game-card-shell,
.feature-island-card.game-card:active .game-card-shell {
  outline-offset: 2px;
  outline-width: 2px;
  transform: translate3d(0, 0, 0) scale(.992);
}

.game-card:hover .game-cover-frame,
.game-card:focus-within .game-cover-frame,
.game-card:hover .game-cover,
.game-card:focus-within .game-cover {
  transform: none;
}

.game-card:hover .game-cover img,
.game-card:focus-within .game-cover img {
  transform: translateZ(0) scale(1.01);
}

@media (pointer: coarse) {
  .game-card:active .game-card-shell,
  .game-card:focus-within .game-card-shell,
  .feature-island-card.game-card:active .game-card-shell,
  .feature-island-card.game-card:focus-within .game-card-shell {
    border-color: var(--game-card-border-hover);
    background-color: var(--game-card-bg-active);
    outline-color: var(--game-card-outline);
    outline-offset: var(--carousel-outline-active, .1875rem);
    outline-width: var(--carousel-outline-active, .1875rem);
    transform: translate3d(0, 0, 0) scale(.992);
    box-shadow: var(--carousel-control-shadow, 0 6px 16px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.16));
  }
}

/* Runtime rendering: card/API rows stay light during first paint. */
.api-content-row {
  content-visibility: auto;
  contain-intrinsic-size: 620px;
  overflow-anchor: none;
}

.api-content-stage,
.content-row-rail {
  contain: layout paint;
  overflow-anchor: none;
}

.game-card,
.feature-island-card,
.game-card-shell {
  contain: layout paint style;
}

.api-section-more {
  display: flex;
  justify-content: center;
  margin: 4px 0 18px;
}

.api-section-more-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 14px;
  border: 1px solid var(--interactive-soft-border);
  border-radius: 12px;
  color: rgba(255,255,255,.84);
  background: var(--interactive-soft-bg);
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .02em;
  cursor: pointer;
}

.api-section-more-button span {
  color: rgba(255,255,255,.56);
  font-size: 10.5px;
  font-weight: var(--text-weight-ui);
}

.api-section-more-button:hover,
.api-section-more-button:focus-visible {
  color: #fff;
  border-color: rgba(255,255,255,.18);
  background: var(--interactive-soft-bg-hover);
}

@media (max-width: 768px) {
  .content-row-rail,
  .featured-rail,
  .news-rail {
    will-change: auto;
  }

  .game-card-shell {
    background-color: var(--game-card-bg);
    box-shadow: var(--game-card-shadow-mobile);
    backdrop-filter: var(--game-card-mobile-backdrop);
    -webkit-backdrop-filter: var(--game-card-mobile-backdrop);
    transition: border-color .12s ease, background-color .12s ease;
  }

  .game-card:hover,
  .feature-island-card:hover,
  .news-card:hover {
    transform: none;
  }

  .game-card:hover .game-card-shell,
  .game-card:focus-within .game-card-shell {
    box-shadow: var(--game-card-shadow-mobile);
  }

  .game-progress-track {
    min-height: var(--game-progress-height-mobile, 18px);
  }

  .game-progress-value {
    font-size: 10.5px;
  }

  .game-progress-fill {
    box-shadow: none;
  }
}

/* Live player chip: shared game cards */
.game-cover,
.feature-cover,
.game-cover-frame {
  position: relative;
}

.game-online-chip {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 62px;
  min-height: 28px;
  padding: 4px 9px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 999px;
  color: rgba(255, 255, 255, .96);
  background: rgba(13, 16, 24, .68);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .10), 0 6px 16px rgba(0, 0, 0, .18);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .01em;
  font-variant-numeric: tabular-nums;
  pointer-events: none;
  white-space: nowrap;
  transition: opacity .16s ease, border-color .16s ease, background-color .16s ease;
}

.game-online-chip--cover {
  position: absolute;
  z-index: 5;
  top: 8px;
  right: 8px;
}

.game-online-chip-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  color: currentColor;
}

.game-online-chip-icon svg {
  display: block;
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.game-online-chip-value {
  display: inline-block;
  min-width: 24px;
  text-align: right;
}

.game-online-chip.is-loading {
  opacity: .72;
}

.game-online-chip.is-ready,
.game-online-chip.is-fallback {
  opacity: 1;
}

@media (max-width: 620px) {
  .game-online-chip--cover {
    top: 7px;
    right: 7px;
  }

  .game-online-chip {
    min-width: 58px;
    min-height: 26px;
    padding-inline: 8px;
    gap: 5px;
    font-size: 10.5px;
  }

  .game-online-chip-icon,
  .game-online-chip-icon svg {
    width: 17px;
    height: 17px;
  }
}

/* Render stability without scroll locking. */
.catalog-page,
.news-section,
.discovery-sections,
.catalog-control-section {
  overflow-anchor: none;
}

.news-section:not([hidden]) {
  min-height: clamp(286px, 25vw, 448px);
}

.news-section:not([hidden]) .news-carousel-stage,
.news-section:not([hidden]) .news-rail {
  min-height: clamp(226px, 20vw, 356px);
}

.discovery-dynamic-rows--top:not([data-render-fingerprint]) {
  min-height: clamp(282px, 25vw, 392px);
}

.discovery-dynamic-rows--rest:not([data-render-fingerprint]) {
  min-height: clamp(120px, 11vw, 190px);
}

.provider-filter-strip:not([data-render-fingerprint]) {
  min-height: 48px;
}

@media (max-width: 760px) {
  .news-section:not([hidden]) {
    min-height: clamp(292px, 76vw, 408px);
  }

  .news-section:not([hidden]) .news-carousel-stage,
  .news-section:not([hidden]) .news-rail {
    min-height: clamp(238px, 66vw, 348px);
  }

  .discovery-dynamic-rows--top:not([data-render-fingerprint]) {
    min-height: clamp(318px, 88vw, 430px);
  }
}

/* Urutan layout: Kemenangan Besar -> kontrol -> 20 Teratas. */
.discovery-sections--top {
  padding-block: clamp(2px, .45vw, 8px) clamp(4px, .65vw, 10px);
  overflow-anchor: none;
}

.discovery-sections--top .content-row:first-child {
  margin-top: 0;
}

.discovery-sections--top[hidden] {
  display: none;
}

.provider-empty-state small {
  display: block;
  max-width: 420px;
  margin-top: 8px;
  color: var(--muted-2, rgba(226, 232, 240, .62));
  font-size: clamp(12px, 1.8vw, 14px);
  font-weight: 700;
  line-height: 1.45;
}


/* Card title and spacing stability. */
.feature-title-link,
.game-title-link,
.news-card-title {
  min-height: 2.34em;
  line-height: 1.17;
  text-wrap: balance;
}

.news-card-title {
  display: -webkit-box;
  min-height: 3.5em;
  max-height: 3.65em;
  overflow: hidden;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}

.news-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  background: rgba(255,255,255,.055);
  box-shadow: none;
}

.news-card-body {
  display: grid;
  align-content: start;
  gap: clamp(10px, 1vw, 14px);
  min-height: clamp(132px, 11vw, 168px);
}

.content-row {
  margin-bottom: clamp(18px, 2vw, 32px);
}

.content-row-stage {
  padding-block: 2px;
}

@media (max-width: 560px) {
  .feature-title-link,
  .game-title-link {
    min-height: 2.38em;
    -webkit-line-clamp: 2;
  }

  .news-card-title {
    min-height: 3.5em;
    max-height: 3.7em;
  }

  .news-card-body {
    min-height: 128px;
  }
}

/* Continuous section canvas for public content. */
.discovery-sections,
.featured,
.news-section,
.catalog {
  background: transparent;
}

.discovery-sections--top {
  background: transparent;
}

.game-card:hover .game-card-shell,
.game-card:focus-within .game-card-shell,
.feature-island-card.game-card:hover .game-card-shell,
.feature-island-card.game-card:focus-within .game-card-shell {
  box-shadow: none;
}

/* === carousel.css === */
/* Carousel, rail, and card interaction layer.
   Global color/control tokens are defined in theme.css. */
.featured-carousel-stage,
.content-row-stage,
.news-carousel-stage {
  overflow: visible;
  --content-slider-pad: var(--content-fade-mobile);
}

.content-row-stage {
  --content-row-control-y: var(--control-y, 72px);
  --control-y: var(--content-row-control-y);
  --control-inline: 0px;
  overflow: visible;
}

.featured-rail,
.content-row-rail,
.news-rail {
  -webkit-mask-image: linear-gradient(90deg, #fff 0, #fff calc(100% - var(--content-slider-pad)), rgba(255,255,255,.42) calc(100% - .35rem), transparent 100%);
  mask-image: linear-gradient(90deg, #fff 0, #fff calc(100% - var(--content-slider-pad)), rgba(255,255,255,.42) calc(100% - .35rem), transparent 100%);
  scroll-padding-inline: var(--content-slider-pad);
  will-change: scroll-position;
}

.feature-island-card,
.game-card,
.game-card-shell {
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle);
  outline-style: solid;
  outline-width: 0;
  transform: translateZ(0);
  backface-visibility: hidden;
  transition: opacity .22s ease-out, outline-color .14s ease-out, outline-offset .14s ease-out, outline-width .14s ease-out, transform .14s ease-out, border-color .14s ease-out, background-color .14s ease-out, box-shadow .14s ease-out;
}

.feature-cover,
.game-cover-frame,
.game-cover {
  outline-width: 0;
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle);
  outline-style: solid;
  transition: outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out, transform .15s ease-out;
}

.feature-cover img,
.game-cover img {
  transition: transform .15s ease-out, scale .15s ease-out, filter .15s ease-out;
}

@media (pointer: fine) {
  .feature-island-card:hover,
  .feature-island-card:focus-within,
  .game-card:hover,
  .game-card:focus-within {
    transform: translate3d(0, -.1rem, 0);
  }

  .feature-island-card:hover .game-card-shell,
  .feature-island-card:focus-within .game-card-shell,
  .game-card:hover .game-card-shell,
  .game-card:focus-within .game-card-shell {
    outline-color: rgba(255,255,255,.20);
    outline-offset: 2px;
    outline-width: 1px;
  }

  .feature-island-card:hover .feature-cover,
  .feature-island-card:focus-within .feature-cover,
  .game-card:hover .game-cover-frame,
  .game-card:focus-within .game-cover-frame,
  .game-card:hover .game-cover,
  .game-card:focus-within .game-cover {
    outline-color: transparent;
    outline-offset: 0;
    outline-width: 0;
    transform: translate3d(0, -.04rem, 0);
  }

  .feature-island-card:hover .feature-cover img,
  .feature-island-card:focus-within .feature-cover img,
  .game-card:hover .game-cover img,
  .game-card:focus-within .game-cover img {
    transform: translateZ(0) scale(1.018);
  }
}

.feature-cover,
.game-cover,
.game-cover-frame {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
  overflow: clip;
  position: relative;
  border-radius: var(--game-card-media-radius, var(--game-card-radius, var(--content-card-radius)));
  background: transparent;
}

.feature-cover img,
.game-cover img {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
  position: relative;
  z-index: 1;
}

.feature-top-overlay,
.game-overlay {
  z-index: 2;
}

.age-badge,
.feature-age-badge,
.creator-badge,
.feature-provider-badge {
  box-shadow: 0 1px 0 rgba(255,255,255,.08) inset;
}

.feature-title-wrap,
.game-title-wrap {
  transition: transform .15s ease-out;
}

@media (pointer: fine) {
  .feature-island-card:hover .feature-title-wrap,
  .feature-island-card:focus-within .feature-title-wrap,
  .game-card:hover .game-title-wrap,
  .game-card:focus-within .game-title-wrap {
    transform: translateY(-.15rem);
  }
}

.carousel-prev,
.carousel-next {
  width: var(--carousel-control-size);
  height: var(--carousel-control-size);
  min-width: var(--carousel-control-size);
  min-height: var(--carousel-control-size);
  border-radius: var(--carousel-control-radius);
  opacity: .96;
}

.carousel-prev:disabled,
.carousel-next:disabled,
.carousel-prev[aria-disabled="true"],
.carousel-next[aria-disabled="true"] {
  cursor: default;
  opacity: .36;
  outline-width: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09);
  transform: translate3d(0, -50%, 0) scale(.96);
}

.carousel-prev:disabled:hover,
.carousel-next:disabled:hover,
.carousel-prev[aria-disabled="true"]:hover,
.carousel-next[aria-disabled="true"]:hover {
  outline-width: 0;
  background: var(--carousel-control-bg);
  transform: translate3d(0, -50%, 0) scale(.96);
}

.slider-pagination button,
.news-card {
  transition: opacity .3s ease-out, outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out, transform .15s ease-out;
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle);
  outline-style: solid;
  outline-width: 0;
}

@media (pointer: fine) {
  .news-card:hover,
  .news-card:focus-within {
    outline-color: rgba(255,255,255,.25);
    outline-offset: var(--carousel-outline-active);
    outline-width: var(--carousel-outline-active);
    transform: translate3d(0, -.08rem, 0);
  }
}

@media (min-width: 1280px) {
    .featured-carousel-stage,
  .content-row-stage,
  .news-carousel-stage {
    --content-slider-pad: var(--content-fade-desktop);
  }
}

@media (max-width: 560px) {
  :root {
    --carousel-control-size: 2.5rem;
  }

    .featured-rail,
  .content-row-rail,
  .news-rail {
    -webkit-mask-image: linear-gradient(90deg, #fff 0, #fff calc(100% - 1rem), rgba(255,255,255,.42) calc(100% - .35rem), transparent 100%);
    mask-image: linear-gradient(90deg, #fff 0, #fff calc(100% - 1rem), rgba(255,255,255,.42) calc(100% - .35rem), transparent 100%);
  }
}

/* Content rail controls and card mapping. */
.content-row[data-content-row-top="true"] .content-row-stage {
  --featured-card-width: 216px;
}

.content-row-head {
  align-items: center;
}

.content-row-controls {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  margin-inline-start: auto;
  flex: 0 0 auto;
}

.content-row-controls[hidden] {
  display: none;
}

.content-row-stage .content-rail-button {
  position: absolute;
  z-index: 6;
  top: var(--content-row-control-y, var(--control-y, 50%));
}

.content-row-stage .content-row-prev-button {
  left: var(--control-inline, .5rem);
}

.content-row-stage .content-row-next-button {
  right: var(--control-inline, .5rem);
}

.content-rail-button {
  display: inline-grid;
  place-items: center;
  box-sizing: border-box;
  width: var(--carousel-control-size);
  height: var(--carousel-control-size);
  min-width: var(--carousel-control-size);
  min-height: var(--carousel-control-size);
  padding: 0;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--carousel-control-radius);
  color: var(--carousel-control-color);
  background: var(--carousel-control-bg);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), inset 0 -1px 0 rgba(0,0,0,.12);
  cursor: pointer;
  touch-action: manipulation;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle);
  outline-style: solid;
  outline-width: 0;
  transform: translate3d(0, -50%, 0);
  transition: opacity .15s ease-out, outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out, transform .15s ease-out, background-color .15s ease-out;
}

.content-rail-button:hover:not(:disabled):not([aria-disabled="true"]),
.content-rail-button:focus-visible:not(:disabled):not([aria-disabled="true"]) {
  opacity: 1;
  outline-color: rgba(255,255,255,.35);
  outline-offset: var(--carousel-outline-active);
  outline-width: var(--carousel-outline-active);
  background: linear-gradient(180deg, rgba(255,255,255,.25), rgba(255,255,255,.11));
  transform: translate3d(0, -50%, 0) scale(1.02);
}

.content-rail-button:active:not(:disabled):not([aria-disabled="true"]) {
  transform: translate3d(0, -50%, 0) scale(.985);
}

.content-rail-button:disabled,
.content-rail-button[aria-disabled="true"] {
  cursor: default;
  opacity: .36;
  outline-width: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09);
  transform: translate3d(0, -50%, 0) scale(.96);
}

.content-rail-button .carousel-next-icon,
.content-rail-button .carousel-control-icon {
  width: clamp(17px, 1.25vw, 21px);
  height: clamp(17px, 1.25vw, 21px);
}

.content-rail-button svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.content-row[data-content-row-top="true"] .feature-island-card {
  flex-basis: var(--featured-card-width);
  width: var(--featured-card-width);
}

.feature-top-overlay--single {
  justify-content: flex-end;
}

.feature-provider-badge--epic {
  width: 2.2rem;
  min-width: 2.2rem;
  height: 2.2rem;
  padding-inline: 0;
  border-radius: .46rem;
  background: rgba(8,9,12,.82);
}

.feature-epic-mark {
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: #fff;
  font-size: .56rem;
  font-weight: 950;
  line-height: 1;
  letter-spacing: -.03em;
}


/* Rail stability guard for large/zoomed-out viewports. */
.content-row-stage {
  --catalog-card-width: var(--catalog-card-width, var(--featured-card-width, 196px));
}

.content-row-rail {
  flex-wrap: nowrap;
  min-width: 0;
  max-width: 100%;
}

.content-row-rail > .game-card,
.content-row-rail > .feature-island-card {
  flex-shrink: 0;
}


/* Responsive control sizing and hover rhythm for all rail sections. */
.news-carousel-stage {
  --carousel-control-size: clamp(50px, 3.5vw, 62px);
  --control-inline: clamp(2px, .6vw, 10px);
}

.featured-carousel-stage,
.content-row-stage {
  --control-inline: clamp(2px, .5vw, 8px);
}

.news-carousel-stage .carousel-prev,
.news-carousel-stage .carousel-next,
.content-row-stage .content-rail-button,
.featured-carousel-stage .carousel-prev,
.featured-carousel-stage .carousel-next {
  border-radius: 999rem;
  backdrop-filter: blur(.5rem) saturate(145%);
  -webkit-backdrop-filter: blur(.5rem) saturate(145%);
}

.news-carousel-stage .carousel-control-icon {
  width: clamp(21px, 1.7vw, 26px);
  height: clamp(21px, 1.7vw, 26px);
}

.content-row-stage .content-rail-button .carousel-control-icon,
.featured-carousel-stage .carousel-control-icon {
  width: clamp(18px, 1.4vw, 23px);
  height: clamp(18px, 1.4vw, 23px);
}

@media (max-width: 640px) {
  .news-carousel-stage {
    --carousel-control-size: 44px;
    --control-inline: 2px;
  }

  .content-row-stage,
  .featured-carousel-stage {
    --carousel-control-size: 40px;
    --control-inline: 2px;
  }
}

/* === responsive.css === */
@media (min-width: 1440px) {

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 6;
    --catalog-card-width: 204px;
    --featured-card-width: 204px;
  }
}

@media (min-width: 1800px) {

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 7;
    --catalog-card-width: 212px;
    --featured-card-width: 212px;
  }
}

@media (max-width: 1120px) {

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 4;
    --catalog-card-width: 188px;
    --featured-card-width: 188px;
  }

  .brand-copy small,
  .sign-in-link {
    display: none;
  }
}

@media (max-width: 980px) {
  :root {
    --shell: min(100% - 24px, 1440px);
  }

  .section-head,
  .catalog-head,
  .site-footer .shell {
    align-items: stretch;
    flex-direction: column;
  }

  .toolbar {
    width: 100%;
    grid-template-columns: minmax(0, 1fr) minmax(126px, 150px);
    gap: 10px;
    margin-left: 0;
  }

  .catalog-search-form,
  .sort-menu,
  .sort-menu__button {
    width: 100%;
    min-width: 0;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 3;
    --catalog-card-width: 180px;
    --featured-card-width: 180px;
  }
}

@media (max-width: 760px) {
  :root {
    --shell: min(100% - 22px, 1440px);
  }

  .discovery-sections,
  .featured,
  .news-section,
  .catalog {
    padding-block: 16px;
  }

  .toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(116px, 142px);
    gap: 8px;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 2;
    --catalog-card-width: clamp(158px, 43vw, 184px);
    --featured-card-width: clamp(158px, 43vw, 184px);
    --game-card-gap: 12px;
    --catalog-card-gap: var(--game-card-gap);
    --featured-card-gap: var(--game-card-gap);
  }

  .featured-rail,
  .content-row-rail,
  .news-rail {
    padding-right: 16px;
  }

  .dialog-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

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

  .dialog-card > img {
    min-height: 250px;
    max-height: 360px;
  }
}

@media (max-width: 560px) {
  .catalog-control-section {
    padding-block: 10px 4px;
  }

  .discovery-sections--rest {
    padding-block-start: 4px;
  }

  :root {
    --shell: min(100% - 18px, 1440px);
  }

  .section-head,
  .catalog-head {
    gap: 12px;
    margin-bottom: 14px;
  }

  .section-title-link h2,
  .section-head h2,
  .catalog-head h2 {
    font-size: clamp(23px, 6.4vw, 26px);
    line-height: 1.08;
  }

  .eyebrow {
    min-height: 26px;
    padding-inline: 10px;
    font-size: 10.5px;
    letter-spacing: .075em;
  }

  .toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(86px, 104px);
    gap: 6px;
  }

  .search,
  .sort-menu__button {
    min-height: 40px;
  }

  .search {
    border-radius: 999px;
  }

  .sort-menu__button {
    border-radius: 16px;
  }

  .search__input {
    min-height: 40px;
    padding-inline: 4px;
    font-size: 16px;
  }

  .search__submit,
  .search__close {
    width: 30px;
    height: 30px;
    margin: 0;
  }

  .catalog-search-form .search__close {
    display: grid;
  }

  .sort-menu__button {
    padding-inline: 10px;
    font-size: 12px;
    gap: 6px;
  }

  .sort-menu__button > svg {
    display: none;
  }

  .category-strip {
    flex-wrap: nowrap;
    gap: 8px;
    padding: 1px 2px 7px;
    margin-bottom: 7px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-padding-inline: 2px;
  }

  .category-chip {
    min-height: 34px;
    padding-inline: 12px;
    border-radius: 15px;
    font-size: 12px;
  }

  .catalog-status {
    align-items: center;
    gap: 8px;
    min-height: 30px;
    margin-bottom: 10px;
    font-size: 12px;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --fn-slider--slides-in-view: 2;
    --catalog-card-width: clamp(148px, calc((100vw - 46px) / 2), 172px);
    --featured-card-width: clamp(148px, calc((100vw - 46px) / 2), 172px);
    --game-card-gap: 10px;
    --catalog-card-gap: var(--game-card-gap);
    --featured-card-gap: var(--game-card-gap);
  }

  .featured-rail,
  .content-row-rail,
  .news-rail {
    padding-top: 8px;
    padding-right: 14px;
    padding-bottom: 10px;
  }

  .feature-top-overlay,
  .game-overlay {
    inset: 6px 6px auto;
    gap: 5px;
  }

  .feature-provider-badge,
  .feature-age-badge,
  .creator-badge,
  .age-badge,
  .island-code,
  .news-tag,
  .news-date {
    min-height: 22px;
    padding-inline: 7px;
    font-size: 10px;
  }

  .feature-title-wrap,
  .game-title-wrap {
    display: none;
  }

  .game-progress {
    margin-top: 7px;
  }

  .game-progress-track {
    min-height: var(--game-progress-height-mobile, 18px);
  }

  .game-progress-value {
    font-size: 10.8px;
  }

  .game-card-shell {
    padding: 5px;
    border-radius: 14px;
  }

  .game-cover,
  .game-cover-frame {
    border-radius: 10px;
  }

  .game-card-actions {
    gap: 5px;
    margin-top: 7px;
  }

  .game-action-button {
    min-height: 28px;
    padding-inline: 9px;
    font-size: 10.4px;
  }

  .feature-title-link,
  .game-title-link,
  .news-card-title {
    font-size: 12.5px;
  }

  .carousel-prev,
  .carousel-next {
    width: var(--carousel-control-size, 40px);
    height: var(--carousel-control-size, 40px);
    --control-inline: 4px;
  }

  .carousel-next-icon,
  .carousel-control-icon {
    width: clamp(17px, 4.8vw, 20px);
    height: clamp(17px, 4.8vw, 20px);
  }

  .slider-pagination,
  .featured-slider-pagination {
    max-width: min(220px, 62vw);
    gap: 5px;
    margin-top: 8px;
    padding: 4px 7px;
  }

  .slider-pagination button button,
  .featured-slider-pagination button {
    width: 12px;
    height: 3px;
  }

  .slider-pagination button[data-fnui-is-active="true"] button[data-fnui-is-active="true"],
  .featured-slider-pagination button[data-fnui-is-active="true"],
  .slider-pagination button._1dfuy4s2 button._1dfuy4s2,
  .featured-slider-pagination button._1dfuy4s2 {
    width: 24px;
  }

  .news-card {
    flex-basis: clamp(240px, 78vw, 300px);
    width: clamp(240px, 78vw, 300px);
    border-radius: 18px;
  }

  .news-card-body {
    gap: 9px;
    padding: 12px;
  }

  .site-footer .shell {
    gap: 8px;
    font-size: 12px;
  }

  .game-dialog.is-pattern-mode {
    width: min(344px, calc(100vw - 30px));
    max-height: calc(100dvh - 54px);
    border-radius: 22px;
  }

  .game-dialog.is-pattern-mode .dialog-card {
    max-height: calc(100dvh - 54px);
  }

  .game-dialog.is-pattern-mode .dialog-body {
    gap: 10px;
    padding: 18px;
  }

  .game-dialog.is-pattern-mode .eyebrow {
    min-height: 22px;
    width: fit-content;
    padding-inline: 9px;
    font-size: 9px;
  }

  .game-dialog.is-pattern-mode .dialog-body h3 {
    max-width: calc(100% - 36px);
    font-size: clamp(22px, 7vw, 28px);
    line-height: 1.02;
    letter-spacing: -.04em;
  }

  .game-dialog.is-pattern-mode .dialog-body dl {
    display: none;
  }

  .game-dialog.is-pattern-mode .dialog-patterns {
    gap: 8px;
  }

  .game-dialog.is-pattern-mode .dialog-patterns-head {
    font-size: 11px;
  }

  .game-dialog.is-pattern-mode .dialog-pattern-list {
    gap: 6px;
  }

  .game-dialog.is-pattern-mode .dialog-pattern-item {
    gap: 2px 8px;
    padding: 9px 11px;
    border-radius: 13px;
  }

  .game-dialog.is-pattern-mode .dialog-pattern-label,
  .game-dialog.is-pattern-mode .dialog-pattern-item small {
    font-size: 10px;
  }

  .game-dialog.is-pattern-mode .dialog-pattern-item strong {
    font-size: 10.5px;
  }

  .game-pola-preview {
    margin-top: 8px;
    padding: 6px;
    border-radius: 11px;
  }

  .game-pola-preview-list {
    gap: 5px;
  }

  .game-pola-preview-item {
    min-height: 27px;
    padding: 6px;
    border-radius: 8px;
  }

  .game-pola-preview-copy {
    gap: 2px;
  }

  .game-pola-preview-item strong,
  .game-pola-preview-spin {
    font-size: 10px;
  }

  .game-pola-preview-item small,
  .game-pola-preview-feature {
    font-size: 8.8px;
  }

  .dialog-pattern-detail {
    gap: 8px;
    padding: 10px;
    border-radius: 14px;
  }

  .dialog-pattern-section {
    gap: 6px;
    padding: 8px;
    border-radius: 13px;
  }

  .dialog-pattern-section-title {
    font-size: 10px;
  }

  .dialog-pattern-section-rows {
    gap: 5px;
  }

  .dialog-pattern-detail-row {
    min-height: 30px;
    gap: 7px;
    padding: 7px 9px;
    border-radius: 12px;
  }

  .dialog-pattern-detail-row span {
    font-size: 10px;
  }

  .dialog-pattern-detail-row strong {
    font-size: 10.5px;
  }

  .game-dialog.is-pattern-mode .dialog-actions {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-top: 2px;
  }

  .game-dialog.is-pattern-mode .dialog-actions .button {
    min-height: 36px;
    padding-inline: 10px;
    border-radius: 15px;
    font-size: 10.5px;
  }

  .game-dialog.is-pattern-mode .dialog-close {
    top: 10px;
    right: 10px;
    width: 36px;
    height: 36px;
  }

  .game-dialog.is-pattern-mode .dialog-close svg {
    width: 15px;
    height: 15px;
  }

}

@media (max-width: 420px) {
  :root {
    --shell: min(100% - 16px, 1440px);
  }

  .toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(78px, 94px);
  }

  .search,
  .sort-menu__button {
    min-height: 38px;
  }

  .search {
    border-radius: 999px;
  }

  .sort-menu__button {
    border-radius: 14px;
  }

  .search__input {
    min-height: 38px;
    padding-inline: 4px;
  }

  .sort-menu__button {
    padding-inline: 8px;
    font-size: 11.5px;
  }

  .section-title-link h2,
  .section-head h2,
  .catalog-head h2 {
    font-size: clamp(21px, 6.2vw, 24px);
  }

  .category-chip {
    min-height: 27px;
    padding-inline: 11px;
    font-size: 11.5px;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --catalog-card-width: clamp(144px, calc((100vw - 42px) / 2), 164px);
    --featured-card-width: clamp(144px, calc((100vw - 42px) / 2), 164px);
    --game-card-gap: 9px;
    --catalog-card-gap: var(--game-card-gap);
    --featured-card-gap: var(--game-card-gap);
  }

  .featured-rail,
  .content-row-rail,
  .news-rail {
    padding-right: 12px;
  }
}

@media (max-width: 380px) {
  .toolbar {
    grid-template-columns: minmax(0, 1fr) 82px;
    gap: 6px;
  }

  .sort-menu__button {
    padding-inline: 8px;
    font-size: 11px;
  }

  .sort-menu__button > svg {
    display: none;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --catalog-card-width: clamp(136px, calc((100vw - 38px) / 2), 154px);
    --featured-card-width: clamp(136px, calc((100vw - 38px) / 2), 154px);
    --game-card-gap: 8px;
    --featured-card-gap: var(--game-card-gap);
  }

  .creator-badge,
  .feature-provider-badge {
    max-width: calc(100% - 42px);
  }
}

@media (max-width: 340px) {
  :root {
    --shell: min(100% - 14px, 1440px);
  }

  .toolbar {
    grid-template-columns: minmax(0, 1fr) 78px;
  }

  .sort-menu__button span {
    max-width: 56px;
    overflow: hidden;
    text-align: center;
    text-overflow: ellipsis;
  }

  .featured-carousel-stage,
  .content-row-stage {
    --catalog-card-width: 132px;
    --featured-card-width: 132px;
    --game-card-gap: 8px;
    --featured-card-gap: var(--game-card-gap);
  }
}

@media (max-width: 920px) {
  .catalog-controls {
    justify-content: stretch;
  }

  .catalog-controls .toolbar {
    width: 100%;
    margin-left: 0;
  }
}

@media (max-width: 560px) {
  .catalog-control-section {
    padding-block: 6px 4px;
  }

  .discovery-sections--rest {
    padding-block-start: 4px;
  }

  .catalog-control-panel {
    margin-bottom: 0;
  }

  .catalog-controls {
    margin-bottom: 0;
  }

  .catalog-control-panel .catalog-status {
    margin-bottom: 0;
  }
}

@media (max-width: 900px) {
  .content-row[data-content-row-top="true"] .content-row-stage {
    --featured-card-width: 200px;
  }
}

@media (max-width: 640px) {
  .section-head.content-row-head {
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }

  .content-row-controls {
    gap: .4rem;
  }

  .content-rail-button {
    width: var(--carousel-control-size);
    height: var(--carousel-control-size);
  }

  .content-row[data-content-row-top="true"] .content-row-stage {
    --featured-card-width: min(76vw, 204px);
  }
}

@media (max-width: 760px) {

}

@media (max-width: 420px) {

  .eyebrow {
    min-height: 22px;
    padding-inline: 8px;
    font-size: 9.5px;
  }

}

/* === header.css === */
.site-header,
.global-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 90;
  height: var(--header-h);
  border-bottom: 1px solid color-mix(in srgb, var(--text) 6%, transparent);
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.034)),
    var(--header-glass-bg, rgba(16,16,20,.70));
  box-shadow: none;
  backdrop-filter: var(--header-glass-blur, blur(24px) saturate(155%));
  -webkit-backdrop-filter: var(--header-glass-blur, blur(24px) saturate(155%));
}

.global-header.is-elevated {
  border-bottom-color: color-mix(in srgb, var(--text) 8%, transparent);
  background:
    linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04)),
    var(--header-glass-bg-elevated, rgba(16,16,20,.82));
  box-shadow: none;
}

.global-header .bg-filter,
.global-header-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 8% 0%, rgba(255,255,255,.055), transparent 24rem),
    radial-gradient(circle at 92% 0%, rgba(255,255,255,.04), transparent 22rem),
    linear-gradient(90deg, rgba(255,255,255,.032), transparent 44%, rgba(255,255,255,.026));
  opacity: .58;
}

.global-header__nav {
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  column-gap: clamp(16px, 2.2vw, 36px);
  width: 100%;
  max-width: none;
  height: 100%;
  box-sizing: border-box;
  padding-inline: max(clamp(14px, 2vw, 34px), env(safe-area-inset-left));
  margin-inline: 0;
}

.header-brand,
.property-logo {
  display: inline-flex;
  grid-column: 1;
  align-items: center;
  justify-content: flex-start;
  justify-self: start;
  flex: 0 0 auto;
  width: clamp(116px, 10vw, 152px);
  min-width: 0;
  color: var(--text);
}

.property-logo__image {
  display: block;
  width: 100%;
  max-width: 152px;
  height: auto;
  max-height: 38px;
  object-fit: contain;
  object-position: left center;
  filter: none;
  user-select: none;
}

.mobile-toolbar {
  display: none;
  margin-left: auto;
}

.mobile-signin-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid var(--header-control-border, var(--line));
  border-radius: 999px;
  color: var(--header-control-text-hover, var(--text));
  background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.055));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .01em;
  text-decoration: none;
  white-space: nowrap;
  touch-action: manipulation;
  transition: color .16s ease, border-color .16s ease, background-color .16s ease, transform .16s ease;
}

.mobile-signin-button:hover,
.mobile-signin-button:focus-visible {
  color: #fff;
  border-color: rgba(255,255,255,.24);
  background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.075));
  transform: translate3d(0, -1px, 0);
}

.global-header__drawer {
  display: contents;
  min-width: 0;
  height: 100%;
}

.main-nav,
.main-nav__list,
.top-nav,
.main-nav__list-item {
  min-width: 0;
}

.main-nav {
  display: flex;
  grid-column: 2;
  align-items: center;
  justify-self: start;
  height: 100%;
}

.main-nav__list,
.top-nav {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(8px, 1vw, 18px);
  width: auto;
  height: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
}

.main-nav__list-item {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  flex: 0 0 auto;
}

.main-nav__list-item[hidden],
.main-nav__list-item--filter[hidden] {
  display: none;
}

.main-nav__list-filler,
.main-nav__list > .menu-heading,
.header-drawer-cta {
  display: none;
}

.mobile-drawer-accordions {
  display: none;
}

.main-nav__link,
.top-nav a,
.top-nav .main-nav__button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-width: 0;
  min-height: 36px;
  padding: 0 clamp(10px, .8vw, 16px);
  border: 0;
  border-radius: 12px;
  color: var(--muted);
  background: transparent;
  box-shadow: none;
  font-size: clamp(11px, .68vw, 12px);
  font-weight: 850;
  line-height: 1;
  letter-spacing: -.012em;
  text-decoration: none;
  white-space: nowrap;
  transition: color .16s ease, background-color .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.main-nav__link:hover,
.main-nav__link:focus-visible,
.main-nav__link.is-active,
.main-nav__link[aria-current="page"],
.top-nav a:hover,
.top-nav a:focus-visible,
.top-nav a.is-active,
.top-nav a[aria-current="page"] {
  color: var(--text);
  background: color-mix(in srgb, var(--text) 8%, transparent);
}

.nav-chevron {
  width: 7px;
  height: 7px;
  flex: 0 0 auto;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  opacity: .78;
  transition: transform .16s ease;
}

.main-nav__list-item[data-open="true"] .nav-chevron,
.dropdown[data-open="true"] .nav-chevron {
  transform: translateY(2px) rotate(225deg);
}

.simple-menu {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 96;
  display: grid;
  gap: 8px;
  min-width: 238px;
  max-width: min(320px, calc(100vw - 24px));
  max-height: min(70vh, 540px);
  padding: 10px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 92%, transparent);
  box-shadow: 0 22px 56px rgba(0,0,0,.32);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overflow: auto;
  transform: translateY(-6px) scale(.985);
  transform-origin: top left;
  transition: opacity .15s ease, visibility .15s ease, transform .15s ease;
}

.simple-menu--right {
  left: auto;
  right: 0;
  transform-origin: top right;
}

.main-nav__list-item[data-open="true"] > .simple-menu,
.dropdown[data-open="true"] > .simple-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.simple-menu .menu-heading {
  display: block;
  padding: 4px 8px 2px;
}

.simple-menu .menu-heading h2 {
  margin: 0;
  color: var(--subtle);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.menu-wrap {
  display: grid;
  gap: 4px;
}

.menu-wrap a,
.menu-wrap button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 38px;
  padding: 0 11px;
  border: 0;
  border-radius: 12px;
  color: var(--muted);
  background: transparent;
  font-size: 13px;
  font-weight: 850;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
}

.menu-wrap a:hover,
.menu-wrap a:focus-visible,
.menu-wrap button:hover,
.menu-wrap button:focus-visible,
.menu-wrap .is-active {
  color: var(--text);
  background: color-mix(in srgb, var(--text) 8%, transparent);
}

.header-toolbar,
.toolbar.header-toolbar {
  display: flex;
  grid-column: 3;
  align-items: center;
  justify-content: flex-end;
  justify-self: end;
  width: auto;
  min-width: 0;
  margin: 0;
}

.tools,
.account-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 0;
}

.tools {
  gap: 8px;
}

.account-actions {
  gap: 7px;
}

.header-search-form {
  width: clamp(244px, 22vw, 360px);
  min-width: 0;
  flex: 0 1 auto;
}

.header-search-form .search {
  grid-template-columns: 30px minmax(0, 1fr) 30px;
  min-width: 0;
  min-height: 30px;
  height: 30px;
  border-color: color-mix(in srgb, var(--text) 18%, transparent);
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
}

.header-search-form .search:hover,
.header-search-form .search:focus-within {
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  background: color-mix(in srgb, var(--surface) 28%, transparent);
  box-shadow: none;
}

.header-search-form .search__input {
  grid-column: 2;
  min-height: 28px;
  padding: 0 2px;
  font-size: 10.5px;
  font-weight: 850;
}

.header-search-form .search__input::placeholder {
  color: color-mix(in srgb, var(--muted) 68%, transparent);
}

.header-search-form .search__submit,
.header-search-form .search__close {
  width: 24px;
  height: 24px;
  margin: 0;
  border: 0;
  box-shadow: none;
}

.header-search-form .search__submit {
  grid-column: 1;
}

.header-search-form .search__close {
  grid-column: 3;
}

.header-search-form .search__icon svg,
.header-search-form .icon-wrapper svg {
  width: 12px;
  height: 12px;
}

.header-search-form .search:not(.is-filled) .search__close {
  opacity: 0;
  pointer-events: none;
}

.header-tool,
.dropdown__button,
.sign-in-link,
.back-button,
.main-cta__primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 13px;
  border: 1px solid var(--header-control-border, var(--line));
  border-radius: 999px;
  color: var(--header-control-text, var(--muted));
  background: var(--header-control-bg, var(--glass-bg));
  box-shadow: 0 1px 0 rgba(255,255,255,.07) inset;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: color .16s ease, background-color .16s ease, border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.header-tool:hover,
.header-tool:focus-visible,
.dropdown__button:hover,
.dropdown__button:focus-visible,
.sign-in-link:hover,
.sign-in-link:focus-visible,
.back-button:hover,
.back-button:focus-visible,
.main-cta__primary:hover,
.main-cta__primary:focus-visible,
.menu-toggle:hover,
.menu-toggle:focus-visible {
  color: var(--text);
  border-color: var(--header-control-border-hover, var(--line-strong));
  background: var(--header-control-bg-hover, var(--glass-bg-strong));
}

.header-tool svg,
.dropdown__button svg,
.back-button svg,
.search__icon svg,
.icon-wrapper svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.dropdown {
  position: relative;
  display: inline-flex;
  min-width: 0;
}

.sign-in-link,
.account-actions .dropdown__button {
  min-height: 31px;
  padding-inline: 13px;
  border-color: var(--header-control-border, rgba(255,255,255,.12));
  color: var(--header-control-text, rgba(255,255,255,.82));
  background: var(--header-control-bg, rgba(255,255,255,.10));
  box-shadow: 0 1px 0 rgba(255,255,255,.09) inset;
  backdrop-filter: blur(14px) saturate(136%);
  -webkit-backdrop-filter: blur(14px) saturate(136%);
}

.account-actions .dropdown__button:hover,
.account-actions .dropdown__button:focus-visible {
  color: var(--header-control-text-hover, var(--text));
  border-color: var(--header-control-border-hover, rgba(255,255,255,.18));
  background: var(--header-control-bg-hover, rgba(255,255,255,.15));
}

.account-actions .register-link,
.register-link,
.main-cta__primary.primary-cta {
  color: var(--header-register-text, #fff);
  border-color: var(--header-register-border, rgba(255,255,255,.18));
  background: var(--header-register-bg, linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.07)));
  box-shadow: var(--header-register-shadow, inset 0 1px 0 rgba(255,255,255,.13));
}

.account-actions .register-link:hover,
.account-actions .register-link:focus-visible,
.register-link:hover,
.register-link:focus-visible,
.main-cta__primary.primary-cta:hover,
.main-cta__primary.primary-cta:focus-visible {
  color: var(--header-register-text-hover, #fff);
  border-color: var(--header-register-border-hover, rgba(255,255,255,.24));
  background: var(--header-register-bg-hover, linear-gradient(180deg, rgba(255,255,255,.21), rgba(255,255,255,.09)));
  box-shadow: var(--header-register-shadow-hover, inset 0 1px 0 rgba(255,255,255,.16));
}

.toolbar__back-wrapper {
  display: none;
}

.menu-toggle {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  padding: 0;
  border: 1px solid var(--header-control-border, var(--line));
  border-radius: 14px;
  color: var(--header-control-text-hover, var(--text));
  background: var(--header-control-bg, var(--glass-bg));
  box-shadow: 0 1px 0 rgba(255,255,255,.08) inset;
  transition: color .16s ease, background-color .16s ease, border-color .16s ease, box-shadow .16s ease;
}

.menu-toggle-glyph {
  position: relative;
  width: 18px;
  height: 14px;
}

.menu-toggle-line {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  opacity: .92;
  transition: top .18s ease, opacity .16s ease, transform .18s ease;
}

.menu-toggle-line:nth-child(1) {
  top: 2px;
}

.menu-toggle-line:nth-child(2) {
  top: 6px;
}

.menu-toggle-line:nth-child(3) {
  top: 10px;
}

.global-header[data-mobile-open="true"] .menu-toggle-line:nth-child(1) {
  top: 6px;
  transform: rotate(45deg);
}

.global-header[data-mobile-open="true"] .menu-toggle-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(.45);
}

.global-header[data-mobile-open="true"] .menu-toggle-line:nth-child(3) {
  top: 6px;
  transform: rotate(-45deg);
}

@media (max-width: 1400px) {
  .header-search-form {
    width: clamp(250px, 24vw, 360px);
  }
}

@media (max-width: 1320px) {
  .header-brand,
  .property-logo {
    width: clamp(112px, 9.4vw, 142px);
  }
}

@media (max-width: 1120px) {
  .header-search-form {
    width: clamp(220px, 23vw, 300px);
  }

  .main-nav__list,
  .top-nav {
    gap: clamp(6px, .8vw, 12px);
  }

  .main-nav__link,
  .top-nav a,
  .top-nav .main-nav__button {
    padding-inline: clamp(8px, .72vw, 12px);
  }
}

@media (min-width: 1280px) {
  .global-header__nav {
    column-gap: clamp(20px, 2.4vw, 42px);
    padding-inline: max(clamp(18px, 2.3vw, 40px), env(safe-area-inset-left));
  }

  .header-brand,
  .property-logo {
    width: clamp(128px, 10.8vw, 170px);
  }

  .property-logo__image {
    max-width: 170px;
    max-height: 42px;
  }

  .main-nav__list,
  .top-nav {
    gap: clamp(10px, 1.08vw, 20px);
  }

  .main-nav__link,
  .top-nav a,
  .top-nav .main-nav__button {
    min-height: 40px;
    padding-inline: clamp(12px, .9vw, 18px);
    border-radius: 14px;
    font-size: clamp(12.4px, .74vw, 13.4px);
  }

  .header-search-form {
    width: clamp(278px, 23vw, 400px);
  }

  .header-search-form .search {
    grid-template-columns: 34px minmax(0, 1fr) 34px;
    min-height: 34px;
    height: 34px;
  }

  .header-search-form .search__input {
    min-height: 32px;
    font-size: 11.6px;
  }

  .header-search-form .search__submit,
  .header-search-form .search__close {
    width: 28px;
    height: 28px;
  }

  .header-search-form .search__icon svg,
  .header-search-form .icon-wrapper svg {
    width: 14px;
    height: 14px;
  }

  .header-tool,
  .dropdown__button,
  .sign-in-link,
  .back-button,
  .main-cta__primary {
    min-height: 40px;
    padding-inline: 15px;
    font-size: 12.8px;
  }

  .sign-in-link,
  .account-actions .dropdown__button {
    min-height: 34px;
    padding-inline: 15px;
  }

  .header-tool svg,
  .dropdown__button svg,
  .back-button svg,
  .search__icon svg,
  .icon-wrapper svg {
    width: 19px;
    height: 19px;
  }
}


@media (min-width: 981px) {
  .global-header__nav {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }

  .main-nav {
    justify-self: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
  }

  .main-nav__list,
  .top-nav {
    justify-content: center;
    width: min(100%, max-content);
    margin-inline: auto;
  }

  .main-nav__list-item[data-key="promosi"],
  .main-nav__list-item[data-key="battle-pass"] {
    display: flex;
  }

  .main-nav__list-item--has-menu > .simple-menu {
    left: 50%;
    right: auto;
    transform: translate(-50%, -6px) scale(.985);
    transform-origin: top center;
  }

  .main-nav__list-item--has-menu[data-open="true"] > .simple-menu {
    transform: translate(-50%, 0) scale(1);
  }

  .simple-menu .menu-wrap a,
  .simple-menu .menu-wrap button {
    justify-content: center;
    text-align: center;
  }

  .header-toolbar,
  .toolbar.header-toolbar {
    justify-self: end;
  }
}

@media (max-width: 980px) {
  :root {
    --header-h: 66px;
  }

  html.mobile-drawer-open,
  body.mobile-drawer-open {
    overflow: hidden;
    overscroll-behavior: none;
  }

  .global-header {
    background:
      linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.034)),
      var(--header-mobile-glass-bg, rgba(16,16,20,.88));
  }

  .global-header__nav {
    display: flex;
    width: 100%;
    gap: 10px;
    padding-inline: max(12px, env(safe-area-inset-left)) max(14px, env(safe-area-inset-right));
    margin-inline: 0;
  }

  .header-brand,
  .property-logo,
  .main-nav,
  .header-toolbar,
  .toolbar.header-toolbar {
    grid-column: auto;
  }

  .mobile-toolbar {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 7px;
    margin-left: auto;
    padding-inline-end: max(3px, env(safe-area-inset-right));
    min-width: 0;
  }

  .global-header__drawer {
    position: fixed;
    inset: var(--header-h) 0 0 0;
    z-index: 88;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    align-content: start;
    align-items: start;
    justify-items: start;
    box-sizing: border-box;
    width: auto;
    max-width: none;
    height: calc(100dvh - var(--header-h));
    max-height: calc(100dvh - var(--header-h));
    min-height: 0;
    padding: clamp(16px, 4svh, 30px) max(clamp(12px, 3.6vw, 24px), env(safe-area-inset-right)) max(24px, calc(env(safe-area-inset-bottom) + 24px)) max(clamp(12px, 3.6vw, 24px), env(safe-area-inset-left));
    scroll-padding-bottom: max(24px, calc(env(safe-area-inset-bottom) + 24px));
    gap: 0;
    border: 0;
    border-top: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
    border-radius: 0;
    color: var(--text);
    background:
      radial-gradient(circle at 0% 0%, rgba(255,255,255,.052), transparent 18rem),
      linear-gradient(180deg, rgba(20,21,28,.985), rgba(12,13,19,.982));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.075), 0 28px 72px rgba(0,0,0,.34);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    overflow: hidden auto;
    overscroll-behavior: contain;
    transform: translateY(-10px);
    transition: opacity .18s ease, visibility .18s ease, transform .18s ease;
  }

  .global-header[data-mobile-open="true"] .global-header__drawer {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .main-nav {
    display: block;
    align-self: start;
    justify-self: start;
    width: min(100%, 370px);
    height: auto;
    min-height: 0;
    margin-inline: 0;
    overflow: visible;
  }

  .main-nav__list,
  .top-nav {
    position: relative;
    display: grid;
    align-items: stretch;
    justify-items: stretch;
    width: 100%;
    height: auto;
    margin-inline: 0;
    gap: 0;
    overflow: hidden;
  }

  .main-nav__list > .menu-heading,
  .main-nav__list > .main-nav__list-item {
    opacity: 1;
    transform: translateX(0);
    transition:
      opacity .22s cubic-bezier(.2,.8,.2,1),
      transform .22s cubic-bezier(.2,.8,.2,1),
      max-height .22s cubic-bezier(.2,.8,.2,1),
      margin .22s cubic-bezier(.2,.8,.2,1);
  }

  .main-nav__list[data-mobile-child-menu-open="true"] > .menu-heading,
  .main-nav__list[data-mobile-child-menu-open="true"] > .main-nav__list-item:not([data-open="true"]) {
    max-height: 0;
    margin: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    transform: translateX(-18px);
  }

  .main-nav__list[data-mobile-child-menu-open="true"] > .main-nav__list-item:not([data-open="true"]) .main-nav__link {
    min-height: 0;
    padding-block: 0;
    border-bottom-color: transparent;
  }

  .main-nav__list > .menu-heading {
    display: block;
    width: 100%;
    padding: 2px 2px 14px;
    text-align: left;
  }

  .main-nav__list > .menu-heading h2 {
    margin: 0;
    color: color-mix(in srgb, var(--text) 92%, transparent);
    font-size: clamp(20px, 5.5vw, 28px);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.03em;
    text-align: left;
  }

  .main-nav__list-item,
  .main-nav__list-item[data-key="promosi"],
  .main-nav__list-item[data-key="battle-pass"] {
    display: grid;
    height: auto;
  }

  .main-nav__link,
  .top-nav a,
  .top-nav .main-nav__button {
    justify-content: flex-start;
    width: 100%;
    min-height: clamp(38px, 7dvh, 48px);
    padding-inline: clamp(12px, 4vw, 18px);
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
    border-radius: 0;
    color: color-mix(in srgb, var(--text) 78%, transparent);
    background: transparent;
    font-size: clamp(15px, 3.9vw, 20px);
    font-weight: 820;
    line-height: 1.08;
    letter-spacing: -.018em;
    text-align: left;
    text-wrap: balance;
  }

  .top-nav .main-nav__button {
    position: relative;
  }

  .top-nav .main-nav__button .nav-chevron {
    position: absolute;
    right: clamp(10px, 3vw, 16px);
    top: 50%;
    margin-top: -6px;
  }

  .main-nav__link:hover,
  .main-nav__link:focus-visible,
  .main-nav__link.is-active,
  .main-nav__link[aria-current="page"],
  .top-nav a:hover,
  .top-nav a:focus-visible,
  .top-nav a.is-active,
  .top-nav a[aria-current="page"] {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 6%, transparent), transparent 82%);
    box-shadow: none;
  }

  .nav-chevron {
    width: 10px;
    height: 10px;
    border-width: 2px;
  }

  .simple-menu,
  .simple-menu--right {
    position: static;
    display: grid;
    min-width: 0;
    max-width: none;
    max-height: 0;
    margin: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    color: var(--text);
    background: transparent;
    box-shadow: none;
    opacity: 0;
    visibility: visible;
    pointer-events: none;
    overflow: hidden;
    transform: translateX(14px);
    transition:
      opacity .22s cubic-bezier(.2,.8,.2,1),
      transform .22s cubic-bezier(.2,.8,.2,1),
      max-height .24s cubic-bezier(.2,.8,.2,1),
      padding .22s cubic-bezier(.2,.8,.2,1);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .main-nav__list-item[data-open="true"] > .simple-menu,
  .dropdown[data-open="true"] > .simple-menu {
    max-height: min(72dvh, 560px);
    margin-block-start: 2px;
    padding: 2px 0 0;
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
    overflow: hidden auto;
  }

  .main-nav__list-item[data-open="true"] > .main-nav__link {
    color: var(--text);
    background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--text) 7%, transparent), transparent);
    border-bottom-color: color-mix(in srgb, var(--text) 8%, transparent);
    box-shadow: none;
  }

  .simple-menu .menu-heading {
    display: none;
    text-align: center;
  }

  .simple-menu .menu-heading h2 {
    margin: 0;
  }

  .menu-wrap {
    display: grid;
    gap: 0;
  }

  .menu-wrap a,
  .menu-wrap button {
    min-height: 34px;
    justify-content: center;
    padding: 0 clamp(10px, 3vw, 16px);
    border-radius: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--text) 8%, transparent);
    color: color-mix(in srgb, var(--text) 72%, transparent);
    background: transparent;
    font-size: clamp(12px, 3vw, 14px);
    font-weight: 740;
    letter-spacing: -.012em;
    text-align: center;
    white-space: normal;
    transition:
      color .16s ease,
      background-color .16s ease,
      transform .16s cubic-bezier(.2,.8,.2,1);
  }

  .menu-wrap a:last-child,
  .menu-wrap button:last-child {
    border-bottom-color: transparent;
  }

  .menu-wrap a:hover,
  .menu-wrap a:focus-visible,
  .menu-wrap button:hover,
  .menu-wrap button:focus-visible,
  .menu-wrap .is-active {
    color: var(--text);
    background: color-mix(in srgb, var(--text) 6%, transparent);
    transform: none;
  }

  .global-header__drawer > .drawer-menu {
    display: none;
  }

  .mobile-drawer-accordions {
    display: grid;
    width: 100%;
    max-width: none;
    justify-self: stretch;
    align-self: start;
    margin: 0;
    padding: 0;
    border-top: 1px solid color-mix(in srgb, var(--text) 11%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--text) 8%, transparent);
  }

  .mobile-drawer-accordion {
    width: 100%;
    border: 0;
    border-bottom: 1px solid color-mix(in srgb, var(--text) 9%, transparent);
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow: visible;
  }

  .mobile-drawer-accordion:last-child {
    border-bottom: 0;
  }

  .mobile-drawer-accordion > summary {
    list-style: none;
  }

  .mobile-drawer-accordion > summary::-webkit-details-marker {
    display: none;
  }

  .mobile-drawer-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: clamp(40px, 7dvh, 48px);
    box-sizing: border-box;
    padding: 0 0 0 2px;
    border: 0;
    color: color-mix(in srgb, var(--text) 86%, transparent);
    background: linear-gradient(90deg, rgba(255,255,255,.028), transparent 72%);
    cursor: pointer;
    user-select: none;
  }

  .mobile-drawer-toggle:hover,
  .mobile-drawer-toggle:focus-visible {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 5%, transparent), transparent 76%);
    outline: none;
  }

  .mobile-drawer-heading {
    min-width: 0;
    color: inherit;
    font-size: clamp(15px, 4.1vw, 19px);
    font-weight: 930;
    line-height: 1.08;
    letter-spacing: -.02em;
    text-align: left;
  }

  .mobile-drawer-indicator {
    display: block;
    flex: 0 0 auto;
    width: 8px;
    height: 8px;
    margin-left: 14px;
    margin-right: 2px;
    border-right: 1.8px solid currentColor;
    border-bottom: 1.8px solid currentColor;
    color: color-mix(in srgb, var(--text) 60%, transparent);
    transform: rotate(45deg) translateY(-2px);
    transition: transform .16s ease, color .16s ease;
  }

  .mobile-drawer-accordion[open] .mobile-drawer-toggle {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 4%, transparent), transparent 78%);
  }

  .mobile-drawer-accordion[open] .mobile-drawer-indicator {
    color: color-mix(in srgb, var(--text) 72%, transparent);
    transform: rotate(225deg) translateY(-1px);
  }

  .mobile-drawer-link-list {
    display: grid;
    justify-items: stretch;
    gap: 0;
    width: 100%;
    padding: 6px 0 10px;
    margin: 0;
  }

  .mobile-drawer-link-list a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    min-height: 31px;
    box-sizing: border-box;
    padding: 7px clamp(14px, 4vw, 22px);
    border-radius: 0;
    color: color-mix(in srgb, var(--text) 66%, transparent);
    background: transparent;
    font-size: clamp(11.5px, 3vw, 13px);
    font-weight: 800;
    line-height: 1.2;
    text-align: left;
    text-decoration: none;
    white-space: normal;
  }

  .mobile-drawer-link-list a:hover,
  .mobile-drawer-link-list a:focus-visible {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 5%, transparent), transparent 76%);
    outline: none;
  }

  .header-toolbar,
  .toolbar.header-toolbar,
  .global-header__drawer .tools,
  .toolbar__back-wrapper {
    display: none;
  }

}

@media (max-width: 560px) {
  :root {
    --header-h: 60px;
  }

  .global-header {
    background:
      linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
      var(--header-mobile-glass-bg, rgba(16,16,20,.88));
    backdrop-filter: var(--header-glass-blur, blur(24px) saturate(155%));
    -webkit-backdrop-filter: var(--header-glass-blur, blur(24px) saturate(155%));
  }

  .global-header .bg-filter,
  .global-header-bg {
    opacity: .36;
  }

  .global-header__nav {
    width: 100%;
    gap: 8px;
    padding-inline: max(10px, env(safe-area-inset-left)) max(12px, env(safe-area-inset-right));
  }

  .header-brand,
  .property-logo {
    width: 112px;
  }

  .property-logo__image {
    max-height: 32px;
  }

  .menu-toggle {
    width: 40px;
    height: 40px;
  }

  .global-header__drawer {
    padding: 16px max(12px, env(safe-area-inset-right)) max(24px, calc(env(safe-area-inset-bottom) + 24px)) max(12px, env(safe-area-inset-left));
  }

  .main-nav {
    width: min(100%, 370px);
  }

  .mobile-signin-button {
    min-height: 36px;
    padding-inline: 12px;
    font-size: 11.4px;
  }


}

@media (max-width: 420px) {
  :root {
    --header-h: 58px;
  }

  .global-header__nav {
    width: 100%;
    gap: 7px;
    padding-inline: max(8px, env(safe-area-inset-left)) max(10px, env(safe-area-inset-right));
  }

  .header-brand,
  .property-logo {
    width: 104px;
  }

  .property-logo__image {
    max-height: 30px;
  }

  .menu-toggle {
    width: 38px;
    height: 38px;
  }

  .mobile-signin-button {
    min-height: 34px;
    padding-inline: 10px;
    font-size: 10.8px;
  }

  .global-header__drawer .main-nav,
  .global-header__drawer .drawer-menu {
    width: min(100%, 340px);
  }

  .mobile-drawer-toggle {
    min-height: 40px;
  }

  .mobile-drawer-link-list a {
    min-height: 30px;
    font-size: 12px;
  }

  .global-header__drawer .main-nav__link,
  .global-header__drawer .top-nav a,
  .global-header__drawer .top-nav .main-nav__button {
    min-height: 40px;
    font-size: 16px;
    line-height: 1.05;
  }
}

@media (min-width: 981px) and (max-width: 1180px) {
  .global-header__nav {
    grid-template-columns: auto minmax(0, 1fr) auto;
    column-gap: clamp(10px, 1.2vw, 18px);
    padding-inline: clamp(12px, 1.6vw, 20px);
  }

  .header-search-form {
    width: clamp(210px, 22vw, 280px);
  }

  .main-nav__list,
  .top-nav {
    gap: clamp(4px, .65vw, 9px);
  }

  .main-nav__link,
  .top-nav a,
  .top-nav .main-nav__button {
    padding-inline: clamp(7px, .62vw, 10px);
  }
}

/* === rail-edge.css === */
/* Rail edge source of truth: lightweight right fade, no legacy mask stacking. */
:root {
  --rail-edge-gutter: clamp(10px, 2vw, 20px);
  --rail-card-safe-space: clamp(14px, 1.9vw, 24px);
  --rail-control-inset: clamp(8px, .95vw, 16px);
  --rail-control-fallback-y: clamp(74px, 6.6vw, 94px);
  --rail-edge-soft-width: clamp(38px, 5.2vw, 88px);
  --rail-edge-soft-alpha: .56;
}

.featured-carousel-stage,
.content-row-stage,
.news-carousel-stage,
.api-spotlight-stage {
  position: relative;
  overflow: visible;
  margin-block: calc(-1 * var(--rail-card-safe-space));
  margin-right: 0;
  padding-block: var(--rail-card-safe-space);
  padding-right: 0;
  isolation: isolate;
  --control-inline: var(--rail-control-inset);
}

.featured-rail,
.content-row-rail,
.news-rail,
.api-spotlight-rail {
  -webkit-mask-image: none;
  mask-image: none;
  scroll-padding-left: var(--rail-card-safe-space);
  scroll-padding-right: calc(var(--rail-card-safe-space) + var(--rail-edge-soft-width));
  padding: calc(var(--rail-card-safe-space) + 2px) calc(var(--rail-card-safe-space) + var(--rail-edge-soft-width)) calc(var(--rail-card-safe-space) + 12px) var(--rail-card-safe-space);
  margin-left: 0;
}

.featured-carousel-stage::before,
.content-row-stage::before,
.news-carousel-stage::before,
.api-spotlight-stage::before {
  content: none;
}

.featured-carousel-stage::after,
.content-row-stage::after,
.news-carousel-stage::after,
.api-spotlight-stage::after {
  content: "";
  position: absolute;
  z-index: 6;
  top: 0;
  right: 0;
  bottom: 0;
  width: var(--rail-edge-soft-width);
  pointer-events: none;
  background:
    linear-gradient(to left,
      rgba(16,16,20,var(--rail-edge-soft-alpha, .56)) 0%,
      rgba(16,16,20,.36) 35%,
      rgba(16,16,20,.14) 68%,
      transparent 100%),
    radial-gradient(ellipse at right center, rgba(51,218,255,.13), transparent 70%);
  box-shadow: none;
  filter: blur(.2px);
  opacity: .96;
}


.feature-cover,
.game-cover,
.game-cover-frame {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
}

.spotlight-card-media,
.news-card-media {
  aspect-ratio: var(--media-ratio, 16 / 9);
}

.feature-cover img,
.game-cover img,
.spotlight-card-media img,
.news-card-media img {
  width: 100%;
  height: 100%;
  object-fit: var(--game-card-media-fit, cover);
}

.carousel-stage > .carousel-prev,
.carousel-stage > .carousel-next,
.content-row-stage .content-rail-button {
  z-index: 8;
}

.carousel-stage > .carousel-prev,
.content-row-stage .content-row-prev-button {
  left: var(--rail-control-inset);
}

.carousel-stage > .carousel-next,
.content-row-stage .content-row-next-button {
  right: var(--rail-control-inset);
}

.content-row-stage .content-rail-button,
.carousel-stage > .carousel-prev,
.carousel-stage > .carousel-next {
  top: var(--control-y, var(--content-row-control-y, var(--rail-control-fallback-y)));
}

.api-spotlight-section {
  padding-block: clamp(14px, 1.7vw, 26px);
}

.api-spotlight-head {
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-right: calc(var(--rail-edge-soft-width) + 8px);
  margin-bottom: 10px;
  flex-wrap: nowrap;
}

.section-head--with-action {
  align-items: center;
  justify-content: space-between;
  flex-direction: row;
}

.section-action-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 clamp(12px, 1.2vw, 18px);
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--text) 82%, transparent);
  background: color-mix(in srgb, var(--surface) 18%, transparent);
  box-shadow: none;
  backdrop-filter: blur(16px) saturate(145%);
  -webkit-backdrop-filter: blur(16px) saturate(145%);
  font-size: clamp(10.5px, .72vw, 12px);
  font-weight: 900;
  letter-spacing: .005em;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  position: relative;
  z-index: 9;
  margin-right: 0;
  transition: border-color .18s ease, background .18s ease, color .18s ease, transform .18s ease;
}


.section-action-link:hover,
.section-action-link:focus-visible {
  border-color: color-mix(in srgb, var(--text) 34%, transparent);
  color: var(--text);
  background: color-mix(in srgb, var(--surface) 28%, transparent);
  box-shadow: none;
  transform: translateY(-1px);
}

@media (prefers-reduced-motion: reduce) {
  .section-action-link {
    transition: none;
  }

  .section-action-link:hover,
  .section-action-link:focus-visible {
    transform: none;
  }
}

.api-spotlight-head .section-title-link {
  justify-content: flex-start;
  flex: 1 1 auto;
  min-width: 0;
}

.api-spotlight-head .section-title-link h2 {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}

.api-spotlight-stage {
  --news-control-y: var(--rail-control-fallback-y);
  --control-y: var(--news-control-y);
  --fn-slider--slides-in-view: 3;
}

.api-spotlight-rail {
  align-items: stretch;
  gap: 16px;
  padding-top: 10px;
  padding-bottom: 18px;
}

.api-spotlight-card {
  display: flex;
  flex: 0 0 clamp(312px, 40vw, 529px);
  width: clamp(312px, 40vw, 529px);
  align-self: stretch;
  border-color: color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 24px;
  background: rgba(255,255,255,.055);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.055);
}

.spotlight-card-hit {
  display: grid;
  grid-template-rows: auto 1fr;
  width: 100%;
  min-height: 100%;
  padding: 0;
  border: 0;
  border-radius: inherit;
  color: inherit;
  background: transparent;
  text-align: left;
}

.spotlight-card-media {
  position: relative;
  border-radius: 24px 24px 0 0;
  background: color-mix(in srgb, var(--surface-2) 90%, transparent);
}

.spotlight-card-media::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 42%;
  pointer-events: none;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.34));
}

.spotlight-card-body {
  display: grid;
  grid-template-rows: minmax(76px, auto) auto;
  align-content: start;
  gap: 12px;
  min-height: 152px;
  height: 100%;
  padding: 16px;
}

.spotlight-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  min-width: 0;
}

.spotlight-card-title {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  min-height: 76px;
  font-size: clamp(17px, 1.65vw, 24px);
  line-height: 1.09;
  letter-spacing: -.025em;
}

.spotlight-card-title-text {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow-wrap: anywhere;
}

.spotlight-card-arrow {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  color: var(--accent);
}

.spotlight-card-arrow svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.spotlight-card-provider,
.spotlight-card-date {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  max-width: 100%;
  min-height: 18px;
  padding: 2px 0;
  color: var(--subtle);
  font-size: clamp(10px, .7vw, 12px);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: .02em;
  text-transform: uppercase;
  white-space: nowrap;
}

.spotlight-card-date {
  position: relative;
  padding-inline-start: 9px;
  color: var(--subtle);
  text-transform: none;
}

.spotlight-card-date::before {
  content: "";
  position: absolute;
  inset-inline-start: 2px;
  top: 50%;
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
  opacity: .72;
  transform: translateY(-50%);
}

@media (max-width: 980px) {
  :root {
    --rail-edge-gutter: 12px;
    --rail-card-safe-space: 12px;
  }

  .api-spotlight-stage {
    --fn-slider--slides-in-view: 2;
    --news-control-y: var(--rail-control-fallback-y);
  }

  .api-spotlight-card {
    flex-basis: clamp(286px, 82vw, 420px);
    width: clamp(286px, 82vw, 420px);
  }
}

@media (max-width: 560px) {
  :root {
    --rail-edge-gutter: 9px;
    --rail-card-safe-space: 12px;
  }

  :root {
    --rail-edge-soft-width: clamp(28px, 9vw, 44px);
    --rail-edge-soft-alpha: .80;
  }

  .featured-rail,
  .content-row-rail,
  .news-rail,
  .api-spotlight-rail {
    padding-left: 10px;
    padding-right: calc(10px + var(--rail-edge-soft-width));
  }

  .api-spotlight-head {
    gap: 8px;
    padding-right: 0;
    margin-bottom: 10px;
  }

  .api-spotlight-head .section-title-link,
  .api-spotlight-head .section-title-link h2 {
    text-align: left;
    white-space: nowrap;
  }

  .section-head--with-action {
    flex-direction: row;
    align-items: center;
    gap: 8px;
  }

  .section-head--with-action h2 {
    font-size: clamp(20px, 6.2vw, 28px);
    line-height: 1;
  }

  .section-action-link {
    min-height: 24px;
    padding: 0 8px;
    font-size: 9.5px;
  }

  .api-spotlight-stage {
    --fn-slider--slides-in-view: 1;
    --news-control-y: var(--rail-control-fallback-y);
  }

  .api-spotlight-card {
    flex-basis: clamp(264px, 86vw, 360px);
    width: clamp(264px, 86vw, 360px);
    border-radius: 20px;
  }

  .spotlight-card-media {
    border-radius: 20px 20px 0 0;
  }

  .spotlight-card-body {
    grid-template-rows: minmax(58px, auto) auto;
    min-height: 128px;
    padding: 13px;
  }

  .spotlight-card-title {
    min-height: 58px;
    font-size: 16px;
    line-height: 1.1;
  }
}


.win-proof-card .win-proof-media,
.win-proof-media {
  background:
    radial-gradient(circle at 82% 12%, color-mix(in srgb, var(--accent-2) 18%, transparent), transparent 42%),
    color-mix(in srgb, var(--surface-2) 92%, transparent);
}

.win-proof-card .win-proof-media img,
.win-proof-media img {
  object-fit: contain;
  object-position: center;
  background: color-mix(in srgb, var(--surface-solid) 90%, transparent);
  filter: saturate(1.02) contrast(1.01);
}

.win-proof-card .spotlight-card-media::after {
  height: 30%;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.20));
}


.feature-island-card:hover,
.feature-island-card:focus-within,
.game-card:hover,
.game-card:focus-within,
.news-card:hover,
.news-card:focus-within {
  position: relative;
  z-index: 7;
}

/* === button-rail-clean.css === */
/* RTPX prev/next reference rebuild
   Uses the uploaded utility-class geometry:
   - control group spans the stage from left to right
   - prev stays on the left edge, next stays on the right edge
   - button size/radius follows _147h8yxl + _147h8yxa + _147h8yxs, not custom pill/round rules */
:root {
  --rtpx-control-edge-inset: clamp(.5rem, 2vw, 2rem);
  --rtpx-control-edge-inset-mobile: .5rem;
  --rtpx-rail-edge-width: clamp(38px, 5vw, 84px);
  --rtpx-rail-card-space: clamp(14px, 1.8vw, 24px);
}

/* Reference utility fallback: these classes are present in the uploaded HTML,
   but not all of them existed in the current project bundle. */
.rtpx-slider-controls._1eu3eal35u,
.rtpx-slider-controls {
  position: absolute;
}

.rtpx-slider-controls._1eu3eal1cq,
.rtpx-slider-controls {
  inset-block-start: 0;
}

.rtpx-slider-controls._1eu3eal17m,
.rtpx-slider-controls {
  inset-block-end: 0;
}

.rtpx-slider-controls._1eu3eal1ki,
.rtpx-slider-controls {
  inset-inline-start: var(--rtpx-control-edge-inset);
}

.rtpx-slider-controls._1eu3eal1fe,
.rtpx-slider-controls {
  inset-inline-end: var(--rtpx-control-edge-inset);
}

.rtpx-slider-controls._1eu3ealpe,
.rtpx-slider-controls {
  display: flex !important;
}

.rtpx-slider-controls._1eu3ealle,
.rtpx-slider-controls {
  align-items: center;
}

.rtpx-slider-controls._1eu3eal1nu,
.rtpx-slider-controls {
  justify-content: space-between;
}

.rtpx-slider-controls._1eu3eal4o,
.rtpx-slider-controls {
  pointer-events: none;
}

.rtpx-slider-controls._1eu3eal5a,
.rtpx-slider-controls {
  z-index: 28;
}

.rtpx-slider-controls.ipkg0e1.ipkg0e5,
.rtpx-slider-controls {
  opacity: 1;
}

.rtpx-slider-controls {
  width: auto;
  height: auto;
  max-width: none;
  padding: 0;
  margin: 0;
  transform: none !important;
  isolation: isolate;
}

/* Every stage must be the positioning boundary for its own left/right controls. */
.news-carousel-stage,
.api-spotlight-stage,
.content-row-stage,
.featured-carousel-stage,
.jackpot-related-stage,
.jackpot-top20-stage,
.game-pola-top20-stage {
  position: relative;
  overflow: visible;
  isolation: isolate;
  --rail-edge-soft-width: var(--rtpx-rail-edge-width);
  --rail-card-safe-space: var(--rtpx-rail-card-space);
}

/* Exact button geometry from the reference CSS. */
.rtpx-slider-controls > button.sjyt1d3,
.carousel-control.sjyt1d3,
.content-rail-button.sjyt1d3,
.news-prev-button.sjyt1d3,
.news-next-button.sjyt1d3 {
  --_147h8yx0: var(--_147h8yx3, transparent);
  --_147h8yx1: var(--kdiqx31c, #fff);
  --_147h8yx2: 2.25rem;
  --_147h8yx3: rgba(236, 237, 238, .30);
  --_147h8yx4: none;
  --sjyt1d0: var(--kdiqx35s, blur(2rem));
  --sjyt1d1: var(--kdiqx35y, rgba(236, 237, 238, .30));

  position: relative !important;
  inset: auto !important;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: var(--_147h8yx2) !important;
  min-width: var(--_147h8yx2) !important;
  height: var(--_147h8yx2) !important;
  min-height: var(--_147h8yx2) !important;
  max-width: none !important;
  aspect-ratio: 1 / 1;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: var(--kdiqx35b, .5rem) !important;
  background-color: var(--_147h8yx0);
  background-image: none;
  color: var(--_147h8yx1, currentColor);
  box-shadow: 0 0 1rem rgba(0, 0, 0, .125);
  text-shadow: none;
  opacity: 1;
  overflow: clip;
  isolation: isolate;
  cursor: pointer;
  transform: none !important;
  filter: none !important;
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* Keep the glass/backplate behavior from the supplied CSS instead of custom gradients. */
.rtpx-slider-controls > button.sjyt1d3.sjyt1d4,
.carousel-control.sjyt1d3.sjyt1d4 {
  isolation: isolate;
  overflow: clip;
  position: relative;
}

.rtpx-slider-controls > button.sjyt1d3.sjyt1d9::before,
.carousel-control.sjyt1d3.sjyt1d9::before,
.content-rail-button.sjyt1d3.sjyt1d9::before,
.news-prev-button.sjyt1d3.sjyt1d9::before,
.news-next-button.sjyt1d3.sjyt1d9::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  border-radius: inherit;
  background-color: var(--sjyt1d1);
  backdrop-filter: var(--sjyt1d0);
  -webkit-backdrop-filter: var(--sjyt1d0);
}

/* Reference hover: no custom scale, no round morph, only outline/animation variables. */
@keyframes _147h8yx5 {
  0% { transform: translateY(0); }
  30% { transform: translateY(-.125rem); }
  100% { transform: translateY(0); }
}

@media (prefers-reduced-motion: no-preference) {
  .rtpx-slider-controls > button.sjyt1d3 > ._147h8yx1b,
  .carousel-control.sjyt1d3 > ._147h8yx1b,
  .content-rail-button.sjyt1d3 > ._147h8yx1b {
    animation: var(--_147h8yx4) .1s linear;
  }
}

@media (pointer: fine) {
  .rtpx-slider-controls > button.sjyt1d3:not([aria-disabled="true"]):not([disabled]):hover,
  .carousel-control.sjyt1d3:not([aria-disabled="true"]):not([disabled]):hover,
  .content-rail-button.sjyt1d3:not([aria-disabled="true"]):not([disabled]):hover,
  .rtpx-slider-controls > button.sjyt1d3:focus-visible,
  .carousel-control.sjyt1d3:focus-visible,
  .content-rail-button.sjyt1d3:focus-visible {
    --_147h8yx4: _147h8yx5;
    outline-color: var(--kdiqx31h, rgba(255,255,255,.35));
    outline-offset: var(--kdiqx353, .1875rem);
    outline-width: var(--kdiqx354, .1875rem);
    outline-style: solid;
    background-color: var(--_147h8yx0);
    box-shadow: 0 0 1rem rgba(0, 0, 0, .125);
    transform: none !important;
    filter: none !important;
  }
}

.rtpx-slider-controls > button.sjyt1d3:disabled,
.rtpx-slider-controls > button.sjyt1d3[aria-disabled="true"],
.carousel-control.sjyt1d3:disabled,
.carousel-control.sjyt1d3[aria-disabled="true"],
.content-rail-button.sjyt1d3:disabled,
.content-rail-button.sjyt1d3[aria-disabled="true"] {
  --_147h8yx0: transparent;
  --_147h8yx1: var(--kdiqx31b, rgba(255,255,255,.35));
  cursor: not-allowed;
  opacity: .5;
  pointer-events: none;
  text-shadow: none;
  outline: 0;
  transform: none !important;
  filter: none !important;
}

/* Exact icon geometry from the reference: 1.5rem base, 1.75rem desktop. */
.rtpx-slider-controls > button.sjyt1d3 > div[aria-hidden="true"],
.carousel-control.sjyt1d3 > div[aria-hidden="true"],
.content-rail-button.sjyt1d3 > div[aria-hidden="true"] {
  position: relative;
  z-index: 1;
  display: flex !important;
  align-items: center;
  justify-content: center;
  width: 1.5rem !important;
  height: 1.5rem !important;
  max-width: none;
  color: inherit;
  pointer-events: none;
  transform: translateZ(0);
}

.rtpx-slider-controls svg,
.carousel-control.sjyt1d3 svg,
.content-rail-button.sjyt1d3 svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

/* Rail safe-space: the right edge fade remains soft but does not pull the buttons inward. */
.featured-rail,
.content-row-rail,
.news-rail,
.api-spotlight-rail,
.jackpot-top20-rail,
.game-pola-top20-rail {
  scroll-padding-inline: calc(var(--rtpx-rail-edge-width) + var(--rtpx-rail-card-space));
  padding-inline-end: calc(var(--rtpx-rail-edge-width) + var(--rtpx-rail-card-space));
}

.content-row-stage::before,
.news-carousel-stage::before,
.api-spotlight-stage::before,
.featured-carousel-stage::before {
  content: "";
  position: absolute;
  z-index: 12;
  inset-block: 0;
  inset-inline-start: 0;
  width: calc(var(--rtpx-rail-edge-width) * .72);
  pointer-events: none;
  background:
    linear-gradient(to right, rgba(16,16,20,.48) 0%, rgba(16,16,20,.22) 52%, transparent 100%);
  box-shadow: none;
}

.content-row-stage::after,
.news-carousel-stage::after,
.api-spotlight-stage::after,
.featured-carousel-stage::after {
  content: "";
  position: absolute;
  z-index: 12;
  inset-block: 0;
  inset-inline-end: 0;
  width: calc(var(--rtpx-rail-edge-width) + 8px);
  pointer-events: none;
  background:
    linear-gradient(to left, rgba(16,16,20,.54) 0%, rgba(16,16,20,.30) 38%, rgba(16,16,20,.10) 72%, transparent 100%),
    radial-gradient(ellipse at right center, rgba(51,218,255,.10), transparent 70%);
  box-shadow: none;
  opacity: .94;
}

@media (min-width: 1280px) {
  .rtpx-slider-controls > button.sjyt1d3,
  .carousel-control.sjyt1d3,
  .content-rail-button.sjyt1d3,
  .news-prev-button.sjyt1d3,
  .news-next-button.sjyt1d3 {
    --_147h8yx2: 2.75rem;
  }

  .rtpx-slider-controls > button.sjyt1d3 > div[aria-hidden="true"],
  .carousel-control.sjyt1d3 > div[aria-hidden="true"],
  .content-rail-button.sjyt1d3 > div[aria-hidden="true"] {
    width: 1.75rem !important;
    height: 1.75rem !important;
  }
}

@media (max-width: 640px) {
  :root {
    --rtpx-control-edge-inset: var(--rtpx-control-edge-inset-mobile);
    --rtpx-rail-edge-width: 34px;
    --rtpx-rail-card-space: 12px;
  }
}

/* Neutralize legacy heavy hover effects everywhere except the rebuilt reference nav buttons. */
@media (hover: hover) and (pointer: fine) {
  :where(.game-card, .feature-island-card, .news-card, .api-spotlight-card, .jackpot-rail-card, .game-pola-card, .winner-card):hover,
  :where(.game-card, .feature-island-card, .news-card, .api-spotlight-card, .jackpot-rail-card, .game-pola-card, .winner-card):focus-within,
  :where(.game-card:hover .game-card-shell, .feature-island-card:hover .game-card-shell, .news-card:hover, .api-spotlight-card:hover, .jackpot-rail-card:hover, .game-pola-card:hover, .winner-card:hover) {
    transform: none !important;
    filter: none !important;
    box-shadow: none !important;
  }

  :where(.game-card:hover img, .feature-island-card:hover img, .news-card:hover img, .api-spotlight-card:hover img, .jackpot-rail-card:hover img, .game-pola-card:hover img, .winner-card:hover img, .game-card:hover .game-cover, .game-card:hover .game-cover-frame, .feature-island-card:hover .feature-cover) {
    transform: none !important;
    filter: none !important;
    scale: 1 !important;
    opacity: 1 !important;
  }

  :where(button, .button, .link-button, .category-chip, .provider-chip, .section-action-link, .api-section-more-button, .game-action-button, .game-pola-button, .header-tool, .menu-toggle, .dropdown__button, .main-cta__primary):hover:not(.sjyt1d3):not(.carousel-control):not(.content-rail-button) {
    transform: none !important;
    filter: none !important;
    box-shadow: none !important;
  }
}

/* Kemenangan Besar rail: controls stay visible and clickable across desktop zoom levels. */
.news-carousel-stage .news-controls.rtpx-slider-controls,
.api-spotlight-stage .news-controls.rtpx-slider-controls {
  inset-inline: clamp(4px, .72vw, 12px) !important;
  z-index: 38;
  pointer-events: none;
}

.news-carousel-stage .news-controls.rtpx-slider-controls > button,
.api-spotlight-stage .news-controls.rtpx-slider-controls > button {
  pointer-events: auto;
  visibility: visible;
}

.news-carousel-stage .news-controls.rtpx-slider-controls > button:disabled,
.news-carousel-stage .news-controls.rtpx-slider-controls > button[aria-disabled="true"],
.api-spotlight-stage .news-controls.rtpx-slider-controls > button:disabled,
.api-spotlight-stage .news-controls.rtpx-slider-controls > button[aria-disabled="true"] {
  opacity: .72;
}

/* === footer.css === */
/* Footer layout and navigation. */
.global-footer {
  --footer-side-space: max(clamp(18px, 3vw, 54px), env(safe-area-inset-left));
  --footer-divider: color-mix(in srgb, var(--text) 18%, transparent);
  --footer-divider-soft: color-mix(in srgb, var(--text) 8%, transparent);
  position: relative;
  isolation: isolate;
  margin-top: clamp(38px, 5vw, 78px);
  padding: clamp(28px, 4vw, 54px) 0 clamp(34px, 5vw, 72px);
  color: var(--muted);
  border-top: 1px solid var(--footer-divider-soft);
}

.global-footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent 0, color-mix(in srgb, var(--accent) 42%, transparent) 50%, transparent 100%);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--text) 5%, transparent);
}

.global-footer .shell {
  box-sizing: border-box;
}

.footer-top,
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(18px, 4vw, 40px);
}

.footer-property-logo {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  color: var(--text);
  text-decoration: none;
}

.footer-property-logo img {
  display: block;
  width: clamp(124px, 13vw, 156px);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 10px 28px rgba(0,0,0,.24));
}

.footer-social {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.footer-social a,
.footer-back-top {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 999px;
  color: var(--text);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.045));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 10px 26px rgba(0,0,0,.16);
  font-size: 12px;
  font-weight: 850;
  line-height: 1;
  text-decoration: none;
  transition: transform .15s ease, border-color .15s ease, background .15s ease, color .15s ease;
}

.footer-social a {
  padding: 0 13px 0 8px;
}

.footer-social a:hover,
.footer-social a:focus-visible,
.footer-back-top:hover,
.footer-back-top:focus-visible {
  color: var(--accent-contrast);
  border-color: color-mix(in srgb, var(--accent) 70%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 96%, #fff 8%), color-mix(in srgb, var(--accent-2) 88%, #fff 4%));
  transform: translateY(-1px);
}

.footer-social-icon {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  color: var(--accent-contrast);
  background: var(--accent);
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.footer-link-columns-wrapper {
  display: grid;
  gap: clamp(20px, 2.4vw, 30px);
  padding-block: clamp(26px, 4vw, 50px);
}

.footer-link-columns-wrapper hr {
  width: 100%;
  height: 1px;
  margin: 0;
  border: 0;
  background: linear-gradient(90deg, var(--footer-divider-soft) 0, var(--footer-divider) 50%, var(--footer-divider-soft) 100%);
  box-shadow: 0 .5px 0 color-mix(in srgb, var(--text) 7%, transparent), 0 -.5px 0 color-mix(in srgb, var(--text) 4%, transparent);
}

.footer-link-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(22px, 6vw, 86px);
}

.footer-link-column {
  display: grid;
  align-content: start;
  gap: 11px;
}

.footer-column-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: fit-content;
  min-height: 28px;
  padding: 0;
  color: var(--text);
  list-style: none;
  cursor: default;
}

.footer-column-toggle::-webkit-details-marker {
  display: none;
}

.footer-column-heading {
  color: inherit;
  font-size: clamp(18px, 1.6vw, 24px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.025em;
}

.footer-column-indicator {
  display: none;
}

.footer-link-list {
  display: grid;
  gap: 11px;
  margin-top: 4px;
}

.footer-link-column a,
.footer-bottom-links a {
  width: fit-content;
  color: var(--subtle);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.25;
  text-decoration: none;
  transition: color .15s ease, transform .15s ease, background .15s ease;
}

.footer-link-column a:hover,
.footer-link-column a:focus-visible,
.footer-bottom-links a:hover,
.footer-bottom-links a:focus-visible {
  color: var(--text);
  transform: translateX(2px);
}

.footer-legal {
  margin-bottom: clamp(24px, 3.4vw, 42px);
}

.footer-legal p {
  max-width: 940px;
  margin: 0;
  color: var(--subtle);
  font-size: clamp(12px, 1.1vw, 14px);
  font-weight: 700;
  line-height: 1.7;
}

.footer-bottom {
  align-items: flex-end;
}

.footer-bottom-copy {
  display: grid;
  gap: 18px;
  max-width: 940px;
}

.footer-bottom-copy p {
  max-width: 860px;
  margin: 0;
  color: var(--subtle);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.65;
}

.footer-bottom-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-back-top {
  flex: 0 0 auto;
  min-height: 44px;
  padding-inline: 18px;
}

@media (min-width: 821px) {
  .global-footer .shell {
    width: 100%;
    max-width: none;
    padding-inline: var(--footer-side-space);
    margin-inline: 0;
  }

  .footer-top {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) minmax(0, max-content) minmax(320px, 1fr);
    align-items: center;
    justify-content: stretch;
  }

  .footer-property-logo {
    grid-column: 1;
    justify-self: start;
  }

  .footer-social {
    grid-column: 3;
    justify-self: end;
    justify-content: flex-end;
  }

  .footer-link-columns-wrapper {
    width: 100%;
  }

  .footer-link-columns {
    width: 100%;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(24px, 8vw, 156px);
    align-items: start;
  }

  .footer-link-column:nth-child(1) {
    justify-items: start;
    text-align: left;
  }

  .footer-link-column:nth-child(2) {
    justify-items: center;
    text-align: center;
  }

  .footer-link-column:nth-child(3) {
    justify-items: end;
    text-align: right;
  }

  .footer-link-column:nth-child(2) a {
    text-align: center;
  }

  .footer-link-column:nth-child(3) a {
    text-align: right;
  }

  .footer-link-accordion,
  .footer-link-accordion:not([open]) .footer-link-list,
  .footer-link-list {
    display: grid;
  }

  .footer-column-toggle {
    pointer-events: none;
    cursor: default;
  }

  .footer-column-indicator {
    display: none;
  }

  .footer-legal p {
    max-width: min(1040px, 76vw);
  }

  .footer-bottom {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: end;
    justify-content: stretch;
  }

  .footer-bottom-copy {
    justify-items: start;
    max-width: min(1120px, 76vw);
  }

  .footer-bottom-copy p {
    max-width: none;
  }

  .footer-bottom-links {
    justify-content: flex-start;
  }

  .footer-back-top {
    justify-self: end;
  }
}

@media (min-width: 821px) and (max-width: 1120px) {
  .footer-top {
    grid-template-columns: minmax(150px, .8fr) minmax(0, 1fr);
  }

  .footer-social {
    grid-column: 2;
  }

  .footer-link-columns {
    gap: clamp(24px, 5vw, 72px);
  }
}

@media (max-width: 820px) {
  .global-footer {
    text-align: center;
  }

  .footer-top,
  .footer-bottom {
    align-items: center;
    flex-direction: column;
    justify-content: center;
    text-align: center;
  }

  .footer-property-logo {
    justify-content: center;
    width: 100%;
  }

  .footer-social {
    justify-content: center;
    width: 100%;
  }

  .footer-link-columns-wrapper.shell {
    width: calc(100% - 24px);
    max-width: none;
    padding-block: 22px 30px;
    margin-inline: auto;
  }

  .footer-link-columns-wrapper hr {
    background: linear-gradient(90deg, transparent 0, var(--footer-divider) 50%, transparent 100%);
    box-shadow: 0 .5px 0 color-mix(in srgb, var(--text) 8%, transparent);
  }

  .footer-link-columns {
    width: 100%;
    grid-template-columns: 1fr;
    justify-items: stretch;
    gap: 0;
    padding: 8px 0;
    text-align: left;
  }

  .footer-link-column {
    width: 100%;
    max-width: none;
    justify-items: stretch;
    align-content: start;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow: visible;
  }

  .footer-column-toggle {
    justify-content: space-between;
    width: 100%;
    min-height: clamp(42px, 7dvh, 50px);
    padding: 0 clamp(0px, 1vw, 6px);
    border: 0;
    border-bottom: 1px solid var(--footer-divider-soft);
    border-radius: 0;
    color: color-mix(in srgb, var(--text) 82%, transparent);
    background: transparent;
    cursor: pointer;
    text-align: left;
    user-select: none;
  }

  .footer-column-toggle:hover,
  .footer-column-toggle:focus-visible {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 5%, transparent), transparent 76%);
    box-shadow: inset 2px 0 0 color-mix(in srgb, var(--accent-2) 52%, transparent);
    outline: none;
  }

  .footer-column-heading {
    flex: 1 1 auto;
    min-width: 0;
    color: inherit;
    font-size: clamp(16px, 4.2vw, 20px);
    line-height: 1.08;
    letter-spacing: -.018em;
    text-align: left;
  }

  .footer-column-indicator {
    display: block;
    flex: 0 0 auto;
    width: 9px;
    height: 9px;
    margin-left: 14px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    color: color-mix(in srgb, var(--text) 52%, transparent);
    transform: rotate(45deg) translateY(-2px);
    transition: transform .16s ease, color .16s ease;
  }

  .footer-link-column[open] .footer-column-toggle {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 78%);
    box-shadow: inset 2px 0 0 color-mix(in srgb, var(--accent-2) 62%, transparent);
  }

  .footer-link-column[open] .footer-column-indicator {
    color: var(--accent);
    transform: rotate(225deg) translateY(-1px);
  }

  .footer-link-list {
    display: none;
    justify-items: stretch;
    gap: 0;
    padding: 6px 0 10px;
    margin-top: 0;
    text-align: left;
  }

  .footer-link-column[open] .footer-link-list {
    display: grid;
  }

  .footer-link-column a {
    width: 100%;
    min-height: 34px;
    padding: 8px clamp(14px, 4vw, 22px);
    border-radius: 0;
    color: color-mix(in srgb, var(--text) 68%, transparent);
    font-size: 13px;
    font-weight: 820;
    line-height: 1.2;
    text-align: left;
  }

  .footer-link-column a:hover,
  .footer-link-column a:focus-visible {
    color: var(--text);
    background: linear-gradient(90deg, color-mix(in srgb, var(--text) 5%, transparent), transparent 76%);
    transform: none;
    outline: none;
  }

  .footer-legal p,
  .footer-bottom-copy p {
    margin-inline: auto;
    text-align: center;
  }

  .footer-bottom-copy {
    justify-items: center;
    width: 100%;
  }

  .footer-bottom-links {
    justify-content: center;
    width: 100%;
  }

  .footer-bottom-links a:hover,
  .footer-bottom-links a:focus-visible {
    transform: translateY(-1px);
  }

  .footer-back-top {
    justify-self: center;
    width: min(100%, 240px);
    margin-inline: auto;
  }
}

@media (max-width: 560px) {
  .global-footer {
    margin-top: 34px;
  }

  .footer-top,
  .footer-bottom-copy {
    gap: 18px;
  }

  .footer-social {
    gap: 8px;
  }

  .footer-social a {
    justify-content: center;
    min-height: 34px;
    padding-right: 11px;
    font-size: 11px;
  }

  .footer-social-icon {
    width: 22px;
    height: 22px;
    font-size: 12px;
  }

  .footer-link-column a,
  .footer-bottom-links a {
    font-size: 12px;
  }

  .footer-bottom-links {
    gap: 10px 14px;
  }
}

/* === visual-glass-clean.css === */
/* RTPX section edge + glass filter clean
   Removes the blue/right-side edge cast and aligns chips/search with the supplied glass token system. */
:root {
  --rtpx-stage-edge-width: clamp(28px, 3.8vw, 58px);
  --rtpx-stage-edge-alpha: .34;
  --rtpx-stage-edge-alpha-soft: .14;
  --rtpx-stage-edge-blur: 7px;
  --rtpx-glass-bg: rgba(236, 237, 238, .085);
  --rtpx-glass-bg-hover: rgba(236, 237, 238, .125);
  --rtpx-glass-bg-active: rgba(236, 237, 238, .165);
  --rtpx-glass-border: rgba(255, 255, 255, .145);
  --rtpx-glass-border-hover: rgba(255, 255, 255, .235);
  --rtpx-glass-text: rgba(255, 255, 255, .76);
  --rtpx-glass-text-active: rgba(255, 255, 255, .94);
  --rtpx-glass-blur: var(--kdiqx35s, blur(2rem));
  --rtpx-card-soft-shadow: 0 10px 26px rgba(0, 0, 0, .18), inset 0 1px 0 rgba(255, 255, 255, .075);
}

/* Neutral rail edges: no cyan/blue blob on the right side of every section. */
.content-row-stage,
.news-carousel-stage,
.api-spotlight-stage,
.featured-carousel-stage,
.jackpot-related-stage,
.jackpot-top20-stage,
.game-pola-top20-stage {
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  overflow: visible;
  isolation: isolate;
}

.content-row-stage::before,
.news-carousel-stage::before,
.api-spotlight-stage::before,
.featured-carousel-stage::before,
.jackpot-related-stage::before,
.jackpot-top20-stage::before,
.game-pola-top20-stage::before {
  content: "";
  position: absolute;
  z-index: 12;
  inset-block: 0;
  inset-inline-start: 0;
  width: calc(var(--rtpx-stage-edge-width) * .82) !important;
  pointer-events: none;
  background: linear-gradient(
    to right,
    rgba(16, 16, 20, var(--rtpx-stage-edge-alpha)) 0%,
    rgba(16, 16, 20, var(--rtpx-stage-edge-alpha-soft)) 46%,
    rgba(16, 16, 20, .035) 74%,
    transparent 100%
  ) !important;
  filter: blur(var(--rtpx-stage-edge-blur));
  opacity: .86;
  box-shadow: none !important;
  mix-blend-mode: normal;
}

.content-row-stage::after,
.news-carousel-stage::after,
.api-spotlight-stage::after,
.featured-carousel-stage::after,
.jackpot-related-stage::after,
.jackpot-top20-stage::after,
.game-pola-top20-stage::after {
  content: "";
  position: absolute;
  z-index: 12;
  inset-block: 0;
  inset-inline-end: 0;
  width: var(--rtpx-stage-edge-width) !important;
  pointer-events: none;
  background: linear-gradient(
    to left,
    rgba(16, 16, 20, var(--rtpx-stage-edge-alpha)) 0%,
    rgba(16, 16, 20, var(--rtpx-stage-edge-alpha-soft)) 46%,
    rgba(16, 16, 20, .035) 74%,
    transparent 100%
  ) !important;
  filter: blur(var(--rtpx-stage-edge-blur));
  opacity: .86;
  box-shadow: none !important;
  mix-blend-mode: normal;
}

/* The rail itself should not expose a colored right block. */
.featured-rail,
.content-row-rail,
.news-rail,
.api-spotlight-rail,
.jackpot-top20-rail,
.game-pola-top20-rail {
  background: transparent !important;
  box-shadow: none !important;
}

/* Soft card surface: keep natural depth, remove hard hover/shadow colors. */
.game-card-shell,
.news-card,
.api-spotlight-card,
.jackpot-rail-card,
.game-pola-card,
.winner-card,
.feature-island-card {
  box-shadow: var(--rtpx-card-soft-shadow) !important;
}

@media (hover: hover) and (pointer: fine) {
  .game-card:hover .game-card-shell,
  .news-card:hover,
  .api-spotlight-card:hover,
  .jackpot-rail-card:hover,
  .game-pola-card:hover,
  .winner-card:hover,
  .feature-island-card:hover {
    box-shadow: var(--rtpx-card-soft-shadow) !important;
    transform: none !important;
    filter: none !important;
  }
}

/* Glass filter/chip/search system from the supplied class tokens. */
.search,
.header-search-form .search,
.catalog-search-form .search,
.mobile-toolbar .search,
.category-chip,
.provider-chip,
.provider-filter-button,
.filter-chip,
.catalog-filter-chip,
.status-chip,
.section-action-link,
.sort-menu__button,
.dropdown__button,
.api-section-more-button {
  color: var(--rtpx-glass-text) !important;
  border: 1px solid var(--rtpx-glass-border) !important;
  background: var(--rtpx-glass-bg) !important;
  background-image: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
  backdrop-filter: var(--rtpx-glass-blur) saturate(145%) !important;
  -webkit-backdrop-filter: var(--rtpx-glass-blur) saturate(145%) !important;
}

.category-chip,
.provider-chip,
.provider-filter-button,
.filter-chip,
.catalog-filter-chip,
.status-chip,
.section-action-link,
.sort-menu__button,
.dropdown__button,
.api-section-more-button {
  border-radius: 999rem !important;
}

.search,
.header-search-form .search,
.catalog-search-form .search,
.mobile-toolbar .search {
  border-radius: 999rem !important;
  min-height: 42px;
}

.search::before,
.search::after,
.search__submit::before,
.search__submit::after,
.search__close::before,
.search__close::after,
.category-chip::before,
.category-chip::after,
.provider-chip::before,
.provider-chip::after,
.provider-filter-button::before,
.provider-filter-button::after,
.filter-chip::before,
.filter-chip::after,
.catalog-filter-chip::before,
.catalog-filter-chip::after {
  content: none !important;
  display: none !important;
}

.search:hover,
.search:focus-within,
.header-search-form .search:hover,
.header-search-form .search:focus-within,
.catalog-search-form .search:hover,
.catalog-search-form .search:focus-within,
.mobile-toolbar .search:hover,
.mobile-toolbar .search:focus-within,
.category-chip:hover,
.category-chip:focus-visible,
.provider-chip:hover,
.provider-chip:focus-visible,
.provider-filter-button:hover,
.provider-filter-button:focus-visible,
.filter-chip:hover,
.filter-chip:focus-visible,
.catalog-filter-chip:hover,
.catalog-filter-chip:focus-visible,
.section-action-link:hover,
.section-action-link:focus-visible,
.sort-menu__button:hover,
.sort-menu__button:focus-visible,
.dropdown__button:hover,
.dropdown__button:focus-visible,
.api-section-more-button:hover,
.api-section-more-button:focus-visible {
  color: var(--rtpx-glass-text-active) !important;
  border-color: var(--rtpx-glass-border-hover) !important;
  background: var(--rtpx-glass-bg-hover) !important;
  background-image: none !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}

.category-chip.is-active,
.category-chip[aria-pressed="true"],
.provider-chip.is-active,
.provider-chip[aria-pressed="true"],
.provider-filter-button.is-active,
.provider-filter-button[aria-pressed="true"],
.filter-chip.is-active,
.filter-chip[aria-pressed="true"],
.catalog-filter-chip.is-active,
.catalog-filter-chip[aria-pressed="true"],
.sort-menu__button[aria-expanded="true"] {
  color: var(--rtpx-glass-text-active) !important;
  border-color: var(--rtpx-glass-border-hover) !important;
  background: var(--rtpx-glass-bg-active) !important;
  background-image: none !important;
  box-shadow: none !important;
}

.provider-filter-strip,
.category-strip,
.catalog-controls,
.toolbar,
.catalog-toolbar,
.header-toolbar,
.mobile-toolbar {
  background: transparent !important;
  box-shadow: none !important;
}

@media (max-width: 640px) {
  :root {
    --rtpx-stage-edge-width: clamp(18px, 7vw, 34px);
    --rtpx-stage-edge-alpha: .28;
    --rtpx-stage-edge-alpha-soft: .10;
    --rtpx-stage-edge-blur: 5px;
  }

  .search,
  .header-search-form .search,
  .catalog-search-form .search,
  .mobile-toolbar .search {
    min-height: 38px;
  }
}
