/* === fonts.css === */
@font-face {
  font-family: "Inter";
  font-display: swap;
  font-style: normal;
  font-weight: 400;
  src: local("Inter Regular"), local("Inter-Regular"),
       url("../font/inter/Inter-Regular.woff2") format("woff2");
}

@font-face {
  font-family: "Inter";
  font-display: swap;
  font-style: normal;
  font-weight: 500;
  src: local("Inter Medium"), local("Inter-Medium"),
       url("../font/inter/Inter-Medium.woff2") format("woff2");
}

:root {
  --font-system: "Inter", sans-serif;
  --font-main: "Inter", sans-serif;
  --font-display: "Inter", var(--font-main);
  --font-display-italic: "Inter", var(--font-display);
}

/* === 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 */
  --font-main: "Inter", sans-serif;
  --font-display: "Inter", var(--font-main);
  --font-display-italic: "Inter", var(--font-display);
  --text-size-body: 15px;
  --text-size-body-mobile: 14px;
  --text-size-ui: clamp(12px, .82vw, 14px);
  --text-size-caption: clamp(10.5px, .72vw, 12px);
  --text-size-overline: clamp(10px, .64vw, 11px);
  --text-line-body: 1.48;
  --text-line-tight: 1.14;
  --text-line-ui: 1.22;
  --text-letter-tight: -.012em;
  --text-letter-ui: 0em;
  --text-letter-overline: .045em;
  --text-weight-body: 400;
  --text-weight-ui: 550;
  --text-weight-strong: 650;
  --text-weight-display: 750;

  /* 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);

  /* Hero/banner */
  --hero-ratio: 1138 / 640;
  --hero-max-width: 1440px;
  --hero-min-height: clamp(360px, 43vw, 640px);
  --hero-mobile-min-height: clamp(460px, 122vw, 620px);
  --hero-side-space: max(clamp(16px, 3vw, 56px), env(safe-area-inset-left));
  --hero-copy-width: min(34rem, 46vw);
  --hero-copy-blur: blur(2rem) saturate(145%);
  --hero-image-blur: blur(56px);
  --hero-reflection-blur: 52px;
  --hero-reflection-opacity: .34;
  --hero-reflection-scale: 1.08;
  --hero-reflection-saturate: 118%;
  --hero-mask-bottom: linear-gradient(to bottom, #000 0%, #000 58%, rgba(0,0,0,.90) 72%, rgba(0,0,0,.58) 88%, transparent 100%);
  --hero-mask-left: linear-gradient(to left, #000 0%, #000 65%, transparent 100%);
  --hero-mask-left-wide: linear-gradient(to left, transparent 0%, #000 35%, #000 65%, transparent 100%);
  --hero-section-lift: 0px;
  --hero-section-gap: clamp(18px, 2.2vw, 34px);

  /* 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. */
html {
  font-family: var(--font-main);
  font-feature-settings: "kern" 1, "liga" 1, "calt" 1;
  text-rendering: geometricPrecision;
  -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: -.035em;
  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);
}

.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.44;
  }

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

/* === 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 12px;
  justify-content: space-between;
  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 {
  min-width: 0;
  overflow: hidden;
  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: 100vw;
  height: 100dvh;
  min-height: 100vh;
  padding: 0;
  margin: 0;
  background: rgba(0, 0, 0, .46);
  opacity: 0;
  pointer-events: none;
  contain: layout paint style;
  transform: translateZ(0);
  transition: opacity .12s ease;
}

.rtpx-loading-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

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

.rtpx-loading-overlay__panel {
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
}

.rtpx-loading-overlay__spinner {
  width: 38px;
  height: 38px;
  display: block;
  border-radius: 999px;
  border: 3px solid rgba(255, 255, 255, .24);
  border-top-color: #fff;
  border-right-color: #fff;
  background: transparent;
  animation: rtpx-loading-spin .62s 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 (prefers-reduced-motion: reduce) {
  .rtpx-loading-overlay { 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 below hero. */
.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: 11px 9px;
    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: 9px 7px;
    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 6px;
    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-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;
}

.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;
}

.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: flex-start;
  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: left;
  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;
  transition: top .18s ease, transform .18s ease;
}

.menu-toggle-line:first-child {
  top: 3px;
}

.menu-toggle-line:last-child {
  top: 10px;
}

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

.global-header[data-mobile-open="true"] .menu-toggle-line:last-child {
  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: 981px) {
  .main-nav__list-item[data-key="promosi"],
  .main-nav__list-item[data-key="battle-pass"] {
    display: flex;
  }
}

@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: min(100% - 24px, 1480px);
    gap: 12px;
    padding-inline: 0;
    margin-inline: auto;
  }

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

  .mobile-toolbar {
    display: flex;
  }

  .global-header__drawer {
    position: fixed;
    inset: var(--header-h) 0 0 0;
    z-index: 88;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: minmax(0, 1fr);
    align-items: stretch;
    box-sizing: border-box;
    width: auto;
    max-width: none;
    height: calc(100dvh - var(--header-h));
    min-height: 0;
    padding: clamp(20px, 5vw, 36px) max(clamp(18px, 5vw, 40px), env(safe-area-inset-right)) clamp(22px, 5vw, 40px) max(clamp(18px, 5vw, 40px), env(safe-area-inset-left));
    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 12% 0%, rgba(255,255,255,.045), transparent 24rem),
      radial-gradient(circle at 88% 4%, rgba(255,255,255,.034), transparent 26rem),
      linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.026)),
      var(--header-mobile-drawer-bg, rgba(16,16,20,.96));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.075), 0 28px 72px rgba(0,0,0,.38);
    backdrop-filter: blur(24px) saturate(156%);
    -webkit-backdrop-filter: blur(24px) saturate(156%);
    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;
    width: min(100%, 480px);
    height: auto;
    min-height: 0;
    margin-inline: auto;
    overflow: visible;
  }

  .main-nav__list,
  .top-nav {
    position: relative;
    display: grid;
    align-items: stretch;
    width: 100%;
    height: auto;
    margin-inline: auto;
    gap: 2px;
    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;
    padding: 2px 2px 12px;
  }

  .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;
  }

  .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: space-between;
    width: 100%;
    min-height: clamp(38px, 7dvh, 48px);
    padding-inline: clamp(6px, 2vw, 12px);
    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;
  }

  .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) 5%, transparent), transparent 76%);
    box-shadow: inset 2px 0 0 color-mix(in srgb, var(--text) 26%, transparent);
  }

  .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, color-mix(in srgb, var(--text) 6%, transparent), transparent 78%);
    border-bottom-color: color-mix(in srgb, var(--text) 8%, transparent);
    box-shadow: inset 2px 0 0 color-mix(in srgb, var(--text) 30%, transparent);
  }

  .simple-menu .menu-heading {
    display: none;
  }

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

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

  .menu-wrap a,
  .menu-wrap button {
    min-height: 34px;
    padding: 0 clamp(8px, 2.3vw, 12px);
    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;
    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: translateX(2px);
  }

  .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: min(100% - 18px, 1480px);
  }

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

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

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

  .global-header__drawer {
    padding: 18px max(18px, env(safe-area-inset-right)) 22px max(18px, env(safe-area-inset-left));
  }

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


}

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

  .global-header__nav {
    width: min(100% - 16px, 1480px);
  }

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

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

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

@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;
}

/* === hero.css === */
/*
  Hero banner and carousel reference layer.
  Mengaktifkan DOM hero yang sudah disiapkan di app.js: mask image, reflection blur,
  autoplay dots progress, pause/play, dan navigasi prev/next.
*/
.hero-banner {
  position: relative;
  isolation: isolate;
  width: 100%;
  min-height: var(--hero-min-height);
  margin-block: 0;
  overflow: clip;
  color: var(--text);
}

.hero-banner[hidden] {
  display: none !important;
}

.hero-banner-stage {
  position: relative;
  min-height: inherit;
  overflow: clip;
  border-radius: 0;
  background: var(--theme-bg, #101014);
}

.hero-slide.has-image::before {
  content: none;
}


.hero-banner-stage::before,
.hero-banner-stage::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.hero-banner-stage::before {
  content: none;
}

.hero-banner-stage::after {
  content: none;
}

.hero-track {
  position: relative;
  min-height: inherit;
  z-index: 1;
}

.hero-slide {
  position: absolute;
  inset: 0;
  min-height: inherit;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, 0, 0) scale(1.012);
  transition: opacity .52s ease, transform .62s ease;
}

.hero-slide.is-active {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
  z-index: 2;
}

.hero-slide.is-exiting {
  opacity: 0;
  z-index: 1;
}

.hero-slide.is-entering .hero-showcase-copy-stack,
.hero-slide.is-active .hero-showcase-copy-stack {
  animation: heroCopyIn .58s ease both;
}

.hero-showcase-frame {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: inherit;
  overflow: clip;
}

.hero-slide.has-image .hero-showcase-frame::before {
  content: none;
}

.hero-showcase-layout {
  position: relative;
  display: grid;
  min-height: inherit;
  align-items: center;
  grid-template-columns: minmax(0, .96fr) minmax(0, 1.2fr);
  gap: clamp(16px, 4vw, 74px);
  padding-block: clamp(28px, 5vw, 72px);
  padding-inline: var(--hero-side-space);
}

.hero-showcase-art {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: visible;
}

.hero-showcase-backdrop {
  position: absolute;
  inset: -10% -12% -18%;
  z-index: 0;
  overflow: hidden;
  opacity: 1;
  transform: translateZ(0);
  filter: none;
  contain: paint;
}

.hero-showcase-backdrop::before {
  content: none;
}

.hero-showcase-backdrop::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(circle at 72% 22%, rgba(51,218,255,.10), transparent 34%),
    linear-gradient(90deg, var(--theme-bg, #101014) 0%, rgba(16,16,20,.22) 28%, rgba(16,16,20,0) 58%),
    linear-gradient(180deg, rgba(16,16,20,.02) 0%, rgba(16,16,20,.10) 68%, var(--theme-bg, #101014) 100%);
}

.hero-showcase-backdrop-image {
  position: absolute;
  inset: -8% -8% -12%;
  z-index: 0;
  width: 116%;
  height: 120%;
  object-fit: cover;
  object-position: center top;
  opacity: var(--hero-reflection-opacity, .34);
  filter: blur(var(--hero-reflection-blur, 52px)) saturate(var(--hero-reflection-saturate, 118%));
  transform: translateZ(0) scale(var(--hero-reflection-scale, 1.08));
  transform-origin: center center;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 12%, #000 78%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 12%, #000 78%, transparent 100%);
}

.hero-showcase-image-shell {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.hero-slide.has-image .hero-showcase-image-shell::before {
  content: none;
}

.hero-showcase-image-mask {
  position: absolute;
  inset-block: 0;
  inset-inline: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  overflow: visible;
  transform-origin: center center;
  z-index: 1;
  background: transparent;
  -webkit-mask-image: var(--hero-mask-left);
  mask-image: var(--hero-mask-left);
}

.hero-showcase-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  isolation: isolate;
  transform: translateZ(0);
  background: transparent;
  -webkit-mask-image: var(--hero-mask-bottom);
  mask-image: var(--hero-mask-bottom);
}


.hero-showcase-backdrop,
.hero-showcase-backdrop-image,
.hero-slide.has-image .hero-showcase-frame::after,
.hero-banner::after,
.hero-banner + .news-section::before {
  will-change: auto;
}

.hero-showcase-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  background:
    radial-gradient(circle at 72% 28%, rgba(51,218,255,.22), transparent 24rem),
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.01));
}

.hero-showcase-beam,
.hero-showcase-spark {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  border-radius: 999rem;
  transform: translateZ(0);
}

.hero-showcase-beam {
  inset-inline-end: 12%;
  inset-block-start: 18%;
  width: min(44vw, 620px);
  height: min(30vw, 420px);
  background: transparent;
  filter: none;
  opacity: 0;
}

.hero-showcase-spark {
  inset-inline-start: 8%;
  inset-block-end: 9%;
  width: min(34vw, 480px);
  height: min(16vw, 220px);
  background: transparent;
  filter: none;
  opacity: 0;
}

.hero-showcase-copy-area {
  position: relative;
  z-index: 3;
  grid-column: 1;
  align-self: center;
  max-width: var(--hero-copy-width);
}

.hero-showcase-copy-shell {
  position: relative;
  isolation: isolate;
}

.hero-showcase-copy-shell::before {
  content: "";
  position: absolute;
  inset: -36px -46px -34px -30px;
  z-index: -1;
  border: 0;
  border-radius: 999rem;
  background:
    radial-gradient(ellipse at 36% 50%,
      rgba(16,16,20,.18) 0%,
      rgba(16,16,20,.09) 46%,
      rgba(16,16,20,.025) 76%,
      transparent 100%);
  opacity: .46;
  filter: blur(22px);
}

.hero-showcase-copy {
  position: relative;
  display: grid;
  align-items: center;
  min-height: clamp(210px, 26vw, 360px);
}

.hero-showcase-copy-stack {
  display: grid;
  gap: clamp(16px, 2vw, 26px);
  justify-items: start;
  max-width: min(100%, 34rem);
}

.hero-showcase-title {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.hero-showcase-logo-block {
  display: grid;
  gap: clamp(9px, 1.1vw, 14px);
}

.hero-showcase-logo-heading,
.hero-showcase-subtitle {
  margin: 0;
}

.hero-showcase-logo-heading {
  max-width: 11ch;
  color: #fff;
  font-size: clamp(38px, 5.8vw, 84px);
  font-weight: 750;
  line-height: .94;
  letter-spacing: -.065em;
  text-wrap: balance;
  text-shadow: none;
}

.hero-showcase-subtitle {
  max-width: 42ch;
  color: rgba(255,255,255,.78);
  font-size: clamp(13px, 1.12vw, 18px);
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -.01em;
  text-shadow: none;
}

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

.hero-primary-cta {
  min-height: clamp(42px, 3.4vw, 52px);
  padding-inline: clamp(18px, 2vw, 28px);
  border-radius: 999rem;
  border: 1px solid rgba(255,255,255,.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.78));
  color: #101014;
  font-size: clamp(12px, .95vw, 14px);
  font-weight: 800;
  letter-spacing: -.01em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.46);
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

.hero-primary-cta:hover,
.hero-primary-cta:focus-visible {
  background: #fff;
  border-color: rgba(255,255,255,.34);
  transform: translate3d(0, -1px, 0);
}

.hero-primary-cta.is-disabled {
  opacity: .55;
  pointer-events: none;
}

.hero-controls {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

.hero-control {
  position: absolute;
  top: 50%;
  display: grid;
  place-items: center;
  width: clamp(38px, 2.8vw, 48px);
  height: clamp(38px, 2.8vw, 48px);
  border: 0;
  border-radius: 999rem;
  color: #fff;
  background: transparent;
  pointer-events: auto;
  transform: translate3d(0, -50%, 0);
  opacity: .92;
  transition: opacity .18s ease, transform .18s ease, background-color .18s ease, border-color .18s ease;
}

.hero-prev {
  inset-inline-start: clamp(10px, 2vw, 28px);
}

.hero-next {
  inset-inline-end: clamp(10px, 2vw, 28px);
}

.hero-control:hover,
.hero-control:focus-visible {
  opacity: 1;
  background: transparent;
  transform: translate3d(0, -50%, 0) scale(1.04);
}

.hero-control svg {
  width: 54%;
  height: 54%;
  fill: currentColor;
}

.hero-dots {
  position: absolute;
  inset-inline: 0;
  inset-block-end: clamp(14px, 2vw, 26px);
  z-index: 6;
  display: flex;
  justify-content: center;
  pointer-events: none;
}

.hero-pagination-shell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  min-height: 0;
  padding-block: .75rem;
  padding-inline: 1rem;
  border: 0;
  border-radius: 999rem;
  background: transparent;
  box-shadow: none;
  pointer-events: auto;
}

.hero-pagination-track {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.hero-dot {
  position: relative;
  display: block;
  width: .5rem;
  height: .5rem;
  overflow: hidden;
  border-radius: 999rem;
  background-color: rgba(255,255,255,.38);
  cursor: pointer;
  transition: width .3s ease-out, background-color .18s ease;
}

.hero-dot:hover,
.hero-dot:focus-visible {
  background-color: rgba(255,255,255,.62);
  outline: 1px solid #fff;
  outline-offset: 2px;
}

.hero-dot.is-active {
  width: 3rem;
}

.hero-dot-progress {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background-color: rgba(255,255,255,.70);
  transform: scaleX(0);
  transform-origin: left;
  animation: heroDotProgress var(--autoplay-duration, 6000ms) linear forwards;
}

.hero-dots.is-paused .hero-dot-progress {
  animation-play-state: paused;
}

.hero-toggle {
  display: grid;
  place-items: center;
  width: 1.25rem;
  height: 1.25rem;
  margin-block: -.25rem;
  margin-inline-end: -.25rem;
  border: 0;
  border-radius: .25rem;
  color: #fff;
  background: transparent;
  cursor: pointer;
  transition: background-color .15s ease, transform .15s ease, border-color .15s ease;
}

.hero-toggle:hover,
.hero-toggle:focus-visible {
  background: transparent;
  transform: scale(1.05);
}

.hero-toggle-icon,
.hero-toggle-icon svg {
  width: 1rem;
  height: 1rem;
  fill: currentColor;
}


/* Soft continuous hero blending. The dark rectangle is removed; the blend now comes from
   image reflection + transparent masks instead of stacked black overlays. */
.hero-slide.has-image .hero-showcase-frame::after {
  content: "";
  position: absolute;
  inset: auto 0 -1px;
  z-index: 2;
  height: clamp(92px, 12vw, 172px);
  pointer-events: none;
  background: linear-gradient(180deg,
    rgba(16,16,20,0) 0%,
    rgba(16,16,20,.018) 42%,
    rgba(16,16,20,.12) 76%,
    var(--theme-bg, #101014) 100%);
  opacity: .72;
}

.hero-slide.has-image .hero-showcase-image-shell::after {
  content: none;
}

/* Reference utility compatibility used by rendered hero markup. */
.no8po04 { color: var(--text); }
.no8po07 { max-width: 120rem; }
.no8po0b { text-align: center; justify-content: center; }
.no8po0g { justify-content: flex-end; }
.no8po0h { max-width: 28rem; }
.no8po0i { margin: auto; }
.no8po0k { z-index: 0; }
.no8po0m { aspect-ratio: 16 / 9; }
.no8po0n { aspect-ratio: 21 / 9; }
.no8po0r { inset: 0; pointer-events: none; position: absolute; }
.no8po0t { z-index: -1; }
.no8po0u { opacity: .8; z-index: -2; }
.no8po0v { position: relative; }
.no8po0x { aspect-ratio: 16 / 9; }
.no8po0y { aspect-ratio: 21 / 9; }
.no8po010 { height: 100%; isolation: isolate; object-position: top center; }
.no8po012 {
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 50%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 50%, transparent 100%);
}
.no8po013 {
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 50%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 50%, transparent 100%);
}
.no8po0w {
  -webkit-mask-image: var(--hero-mask-left);
  mask-image: var(--hero-mask-left);
}
.no8po0u {
  opacity: .8;
}

@keyframes heroDotProgress {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

@keyframes heroCopyIn {
  from {
    opacity: 0;
    transform: translate3d(28px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}


@media (max-width: 1023px) {
  .hero-banner {
    min-height: var(--hero-mobile-min-height);
    margin-block-end: 0;
  }

  .hero-showcase-layout {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: inherit;
    gap: 0;
    padding: clamp(18px, 5vw, 34px) clamp(14px, 4vw, 22px) clamp(78px, 19vw, 112px);
  }

  .hero-showcase-image-mask {
    inset-block-start: 0;
    inset-block-end: auto;
    inset-inline: -10vw;
    width: 120vw;
    max-width: none;
    height: clamp(250px, 62vw, 410px);
    transform: none;
    transform-origin: center 25%;
    -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 74%, transparent 100%);
    mask-image: linear-gradient(to bottom, #000 0%, #000 74%, transparent 100%);
  }

  .hero-showcase-image {
    object-fit: cover;
    object-position: top center;
  }

  .hero-showcase-backdrop {
    inset: -8% -16% -14%;
    opacity: 1;
  }

  .hero-showcase-backdrop-image {
    opacity: .30;
    filter: blur(40px) saturate(116%);
    transform: translateZ(0) scale(1.06);
  }

  .hero-showcase-copy-area {
    grid-column: auto;
    width: min(100%, 560px);
    max-width: 100%;
    align-self: center;
    text-align: center;
    margin-inline: auto;
    transform: translateY(clamp(-10px, -1.8vw, -4px));
  }

  .hero-showcase-copy-shell::before {
    inset: -30px -38px -28px;
    opacity: .62;
    border-radius: 999rem;
    filter: blur(20px);
    background:
      radial-gradient(ellipse at 50% 50%, rgba(16,16,20,.24) 0%, rgba(16,16,20,.12) 48%, rgba(16,16,20,.04) 76%, transparent 100%);
  }

  .hero-showcase-copy {
    min-height: auto;
  }

  .hero-showcase-copy-stack {
    justify-items: center;
    gap: clamp(10px, 2.1vw, 14px);
  }

  .hero-showcase-logo-heading {
    max-width: 12ch;
    font-size: clamp(30px, 9.4vw, 50px);
    line-height: .94;
    text-align: center;
    letter-spacing: -.055em;
  }

  .hero-showcase-subtitle {
    max-width: 34ch;
    font-size: clamp(12.25px, 3vw, 14.5px);
    line-height: 1.36;
    margin-inline: auto;
  }

  .hero-primary-cta {
    min-height: 40px;
    padding-inline: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .hero-showcase-actions {
    justify-content: center;
  }

  .hero-control {
    width: 40px;
    height: 40px;
    opacity: 0;
    transform: translate3d(0, -50%, 0) scale(.96);
  }

  .hero-banner[data-hero-controls="visible"] .hero-control,
  .hero-banner:focus-within .hero-control {
    opacity: .96;
    transform: translate3d(0, -50%, 0) scale(1);
  }

  .hero-pagination-shell {
    min-height: 38px;
    padding: 10px 13px;
    gap: 12px;
  }

  .hero-pagination-track {
    gap: 9px;
  }

  .hero-dot.is-active {
    width: 2.4rem;
  }

  .no8po07 {
    display: flex;
    flex-direction: column;
    height: 100%;
  }

  .no8po0k {
    object-fit: cover;
  }
}


@media (min-width: 540px) and (max-width: 1023px) {
  .hero-banner {
    min-height: clamp(430px, 72vw, 560px);
  }

  .hero-showcase-backdrop-image {
    opacity: .32;
    filter: blur(44px) saturate(116%);
  }

  .hero-showcase-layout {
    padding-block-start: clamp(16px, 3vw, 24px);
    padding-block-end: clamp(72px, 13vw, 96px);
  }

  .hero-showcase-image-mask {
    height: clamp(260px, 58vw, 390px);
  }


  .hero-showcase-copy-area {
    transform: translateY(clamp(-18px, -3vw, -8px));
  }
}

@media (max-width: 539px) {
  .hero-showcase-image-mask {
    height: clamp(238px, 70vw, 330px);
  }

  .hero-showcase-logo-heading {
    font-size: clamp(28px, 10.5vw, 42px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slide,
  .hero-primary-cta,
  .hero-control,
  .hero-dot,
  .hero-toggle {
    transition: none;
  }

  .hero-dot-progress,
  .hero-slide.is-entering .hero-showcase-copy-stack,
  .hero-slide.is-active .hero-showcase-copy-stack {
    animation: none;
  }
}


/* Seamless hero-to-content canvas.
   Keep the first section readable without placing a solid shell-sized rectangle on top
   of the banner. The blend is viewport-wide and transparent at the top, so the hero
   reflection remains natural. */
.hero-banner::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 3;
  height: clamp(124px, 13vw, 214px);
  pointer-events: none;
  background: linear-gradient(180deg,
    rgba(16,16,20,0) 0%,
    rgba(16,16,20,.026) 42%,
    rgba(16,16,20,.14) 74%,
    var(--theme-bg, #101014) 100%);
}

.hero-banner + .news-section {
  position: relative;
  z-index: 6;
  isolation: isolate;
  margin-top: 0;
  padding-top: var(--hero-section-gap);
  background: transparent;
}

.hero-banner + .news-section::before {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(-1 * clamp(72px, 8vw, 138px));
  z-index: -1;
  width: 100vw;
  height: clamp(220px, 24vw, 360px);
  pointer-events: none;
  transform: translateX(-50%);
  background: linear-gradient(180deg,
    rgba(16,16,20,0) 0%,
    rgba(16,16,20,.08) 36%,
    rgba(16,16,20,.30) 70%,
    var(--theme-bg, #101014) 100%);
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 28%, #000 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, #000 28%, #000 100%);
}


/* Desktop zoom-safe hero composition aligned to the supplied no8po reference. */
@media (min-width: 1024px) {
  .hero-banner {
    background: var(--theme-bg, #101014);
  }

  .hero-banner-stage,
  .hero-showcase-frame {
    background: var(--theme-bg, #101014);
  }

  .hero-showcase-layout {
    width: min(100%, 120rem);
    max-width: 120rem;
    margin-inline: auto;
    grid-template-columns: minmax(16rem, calc(50% - 8rem)) minmax(0, 1fr);
    gap: 0;
    padding-inline: clamp(22px, 3.2vw, 64px);
  }

  .hero-showcase-art {
    inset: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: none;
    transform: none;
    overflow: visible;
  }

  .hero-showcase-image-mask {
    inset-block: 0;
    inset-inline-start: calc(64vw - 32rem);
    inset-inline-end: auto;
    width: auto;
    height: 100%;
    max-width: 1400px;
    position: absolute;
    transform-origin: top right;
    -webkit-mask-image: var(--hero-mask-left);
    mask-image: var(--hero-mask-left);
  }

  .hero-slide[data-hero-ratio-mode="21-9"] .hero-showcase-image-mask {
    inset-inline-start: calc(80vw - 55rem);
  }

  .hero-showcase-image {
    object-position: top center;
    -webkit-mask-image: var(--hero-mask-bottom);
    mask-image: var(--hero-mask-bottom);
  }

  .hero-showcase-backdrop {
    inset: -10% -12% -18%;
    opacity: 1;
  }

  .hero-slide.has-image::before {
    content: none;
  }

  .hero-showcase-copy.no8po0c {
    max-width: calc(50vw - 8rem);
  }

  .hero-showcase-copy.no8po0d {
    text-align: start;
    justify-content: start;
  }

  .hero-showcase-copy-area {
    justify-self: start;
    max-width: min(31rem, 34vw);
    transform: translateX(clamp(4px, 1.4vw, 24px));
  }

  .hero-showcase-copy-stack {
    gap: clamp(12px, 1.35vw, 20px);
  }

  .hero-showcase-logo-heading {
    max-width: 10.8ch;
    font-size: clamp(40px, 4.75vw, 76px);
    line-height: .94;
  }

  .hero-showcase-subtitle {
    max-width: 36ch;
  }
}

@media (min-width: 1280px) {
  .hero-banner:not(:last-child) {
    margin-block-end: var(--hero-section-lift);
  }
}

@media (min-width: 1600px) {
  .hero-showcase-image-mask,
  .no8po0w {
    -webkit-mask-image: var(--hero-mask-left-wide);
    mask-image: var(--hero-mask-left-wide);
  }
}

@media (min-width: 1920px) {
  .hero-slide[data-hero-ratio-mode="16-9"] .hero-showcase-image-mask,
  .hero-slide:not([data-hero-ratio-mode="21-9"]) .hero-showcase-image-mask {
    inset-inline-start: auto;
    inset-inline-end: 5.5rem;
  }

  .hero-slide[data-hero-ratio-mode="21-9"] .hero-showcase-image-mask {
    inset-inline-start: auto;
    inset-inline-end: -2rem;
  }
}

@media (min-width: 1024px) and (max-height: 720px) {
  .hero-banner {
    min-height: clamp(310px, 33vw, 520px);
  }

  .hero-showcase-layout {
    padding-block: clamp(18px, 3.4vw, 48px);
  }

  .hero-showcase-copy {
    min-height: clamp(176px, 21vw, 286px);
  }

  .hero-dots {
    inset-block-end: clamp(10px, 1.5vw, 18px);
  }
}


/* Keep the first content heading readable when the reference hero overlap is active. */
.hero-banner + .news-section .section-head {
  position: relative;
  z-index: 7;
  margin-bottom: clamp(10px, 1.35vw, 18px);
}

.hero-banner + .news-section .news-carousel-stage {
  position: relative;
  z-index: 6;
}

/* Do not paint a shell-sized solid panel here; the transition is handled by
   .hero-banner::after and the viewport-wide .news-section::before blend. */
.hero-banner + .news-section,
.hero-banner + .news-section + .discovery-sections--top {
  background: transparent;
}

/* Epic reference carousel controls: original HTML class bridge.
   Only the hero layer consumes these rules, so the public section carousel remains stable. */
.hero-banner ._1eu3ealpe { display: flex; }
.hero-banner ._1eu3ealle { align-items: center; }
.hero-banner ._1eu3ealr6 { flex-direction: column; }
.hero-banner ._1eu3ealrm { flex-direction: row; }
.hero-banner ._1eu3eal1v { flex-wrap: wrap; }
.hero-banner ._1eu3eal1q { flex-shrink: 0; }
.hero-banner ._1eu3eal1oa { justify-content: center; }
.hero-banner ._1eu3eal3x { outline: none; }
.hero-banner ._1eu3eal36a { position: relative; }
.hero-banner ._1eu3eal5a { z-index: 1; }
.hero-banner ._1eu3ealoa { border-radius: 999rem; }
.hero-banner ._1eu3eal82 { gap: 1rem; }
.hero-banner ._1eu3eal7u { gap: .75rem; }
.hero-banner .lyd9ut0:empty { display: none; }

.hero-banner .sjyt1d4 {
  isolation: isolate;
  overflow: clip;
  position: relative;
}
.hero-banner .sjyt1d7 { --sjyt1d0: blur(2rem); }
.hero-banner .sjyt1d9::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  display: block;
  border-radius: inherit;
  background-color: var(--sjyt1d1, var(--kdiqx35z, rgba(236,237,238,.10)));
  -webkit-backdrop-filter: var(--sjyt1d0, var(--kdiqx35s, blur(2rem)));
  backdrop-filter: var(--sjyt1d0, var(--kdiqx35s, blur(2rem)));
}
.hero-banner .sjyt1db { --sjyt1d1: var(--kdiqx35y, rgba(236,237,238,.30)); }
.hero-banner .sjyt1dc { --sjyt1d1: var(--kdiqx35z, rgba(236,237,238,.10)); }

.hero-banner ._1i6fbay4 { max-width: fit-content; }
.hero-banner ._1i6fbay6 {
  --_1i6fbay0: .625rem;
  --_1i6fbay1: .1875rem;
  --_1i6fbay2: var(--kdiqx354, .1875rem);
  outline-width: 0;
  outline-color: transparent;
  outline-offset: var(--_1i6fbay0);
  outline-style: solid;
  overflow: initial;
}
.hero-banner a._1i6fbay4:not([aria-disabled="true"]),
.hero-banner button._1i6fbay4:not([aria-disabled="true"]):not([disabled]) {
  cursor: pointer;
}
.hero-banner button._1i6fbay4:not([aria-disabled="true"]):not([disabled]) > * {
  pointer-events: none;
}
@media (prefers-reduced-motion: no-preference) {
  .hero-banner ._1i6fbay6 {
    transition-duration: .15s;
    transition-property: outline-color, outline-offset, outline-width, transform, background-color, border-color;
    transition-timing-function: ease-out;
  }
}
@media (pointer: fine) {
  .hero-banner a._1i6fbay6:not([aria-disabled="true"]):hover,
  .hero-banner button._1i6fbay6:not([aria-disabled="true"]):not([disabled]):hover,
  .hero-banner ._1i6fbay6:focus-visible {
    outline-color: rgba(255,255,255,.35);
    outline-offset: var(--_1i6fbay1);
    outline-width: var(--_1i6fbay2);
  }
}

.hero-banner ._147h8yx9 {
  --_147h8yx0: var(--_147h8yx3, transparent);
  --_147h8yx1: currentColor;
  --_147h8yx4: none;
  background-color: var(--_147h8yx0);
  box-shadow: 0 0 1rem rgba(0,0,0,.125);
  color: var(--_147h8yx1, currentColor);
  user-select: none;
  -webkit-user-select: none;
}
.hero-banner ._147h8yxa { height: var(--_147h8yx2, 2.25rem); }
.hero-banner ._147h8yxc { --_147h8yx3: rgba(255,255,255,.08); }
.hero-banner ._147h8yxh { --_147h8yx3: #fff; --_147h8yx1: #101014; }

.hero-banner .hero-control._147h8yx9,
.hero-banner .hero-toggle._147h8yx9 {
  --_147h8yx3: rgba(255,255,255,.10);
  --_147h8yx1: #fff;
  background: transparent;
  color: #fff;
}
.hero-banner .hero-control._147h8yx9:hover,
.hero-banner .hero-toggle._147h8yx9:hover,
.hero-banner .hero-control._147h8yx9:focus-visible,
.hero-banner .hero-toggle._147h8yx9:focus-visible {
  background: transparent;
}
.hero-banner .hero-primary-cta._147h8yx9 {
  --_147h8yx3: rgba(255,255,255,.92);
  --_147h8yx1: #101014;
}
.hero-banner ._147h8yxj { --_147h8yx1: #fff; text-shadow: none; }
.hero-banner ._147h8yxl { --_147h8yx2: 2.25rem; border-radius: .5rem; }
.hero-banner ._147h8yxn { --_147h8yx2: 1.25rem; border-radius: .25rem; }
.hero-banner ._147h8yxp { padding-inline: 1.25rem; }
.hero-banner ._147h8yxs { max-width: none; width: var(--_147h8yx2, 2.25rem); }
.hero-banner ._147h8yxt { max-width: none; }
.hero-banner ._147h8yxy { width: 1.5rem; }
.hero-banner ._147h8yx10 { width: 1rem; }
.hero-banner ._147h8yx1a { color: inherit; }
.hero-banner ._147h8yx1b { transform: translateZ(0); }

.hero-control-icon,
.hero-toggle-icon {
  align-items: center;
  justify-content: center;
  color: inherit;
  pointer-events: none;
}
.hero-control-icon svg,
.hero-toggle-icon svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

@keyframes _1dfuy4s0 {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

.hero-banner ._1dfuy4s1 {
  position: relative;
  display: block;
  width: .5rem;
  height: .5rem;
  overflow: hidden;
  border-radius: 99rem;
  background-color: rgba(255,255,255,.40);
  cursor: pointer;
  transition: width .3s ease-out;
}
.hero-banner ._1dfuy4s1:hover { background-color: rgba(255,255,255,.60); }
.hero-banner ._1dfuy4s1:focus-visible,
.hero-banner ._1dfuy4s1:focus {
  outline: 1px solid #fff;
  outline-offset: 2px;
}
.hero-banner ._1dfuy4s2 { width: 3rem; }
.hero-banner ._1dfuy4s3 {
  position: absolute;
  inset: 0;
  border-radius: 99rem;
  background-color: rgba(255,255,255,.60);
  transform: scaleX(0);
  transform-origin: left;
  transition: background-color .2s ease-in-out;
}
.hero-banner ._1dfuy4s5 { animation: _1dfuy4s0 var(--autoplay-duration, 6000ms) linear forwards; }
.hero-banner ._1dfuy4s7 { animation-play-state: paused; }
.hero-banner ._1dfuy4s8 { animation-play-state: running; }
.hero-dots.is-paused ._1dfuy4s3 { animation-play-state: paused; }
[dir="rtl"] .hero-banner ._1dfuy4s3 { transform-origin: right; }

.hero-cta-motion {
  opacity: 1;
  transform: none;
}
.hero-primary-cta .ue0mn5,
.hero-primary-cta .ue0mn7,
.hero-primary-cta .ue0mnh,
.hero-primary-cta ._1udn9kg2 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  line-height: 1.15;
}
.hero-primary-cta ._1udn9kg2 {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 1280px) {
  .hero-banner ._147h8yxl { --_147h8yx2: 2.75rem; }
  .hero-banner ._147h8yxn { --_147h8yx2: 1.5rem; }
  .hero-banner ._147h8yxp { padding-inline: 1.5rem; }
  .hero-banner ._147h8yxy { width: 1.75rem; }
  .hero-banner ._147h8yx10 { width: 1.25rem; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-banner ._1dfuy4s1 { transition: none; }
  .hero-banner ._1dfuy4s3 { display: none; }
}


/* CTA click safety: keep the original nested button markup but ensure the link remains the hit target. */
.hero-showcase-action-motion,
.hero-showcase-actions,
.hero-cta-motion,
.hero-showcase-cta {
  position: relative;
  z-index: 8;
  pointer-events: auto;
}
.hero-showcase-cta[aria-disabled="true"] {
  pointer-events: none;
}
.hero-showcase-cta > span {
  pointer-events: none;
}

/* Keep the hero art clear; reflection layers must never wash the real banner image. */
.hero-showcase-image-mask,
.hero-showcase-image {
  filter: none;
}

/* Original-structure hero prev/next controls.
   The buttons intentionally keep the pasted source class list only; positioning is bound to
   data-hero-prev/data-hero-next so utility classes cannot push them back into normal flow. */
.hero-banner .hero-controls {
  position: absolute;
  inset: 0;
  z-index: 12;
  pointer-events: none;
}

.hero-banner button[data-hero-prev],
.hero-banner button[data-hero-next],
.hero-banner button[data-hero-prev]._1eu3eal36a,
.hero-banner button[data-hero-next]._1eu3eal36a,
.hero-banner button[data-hero-prev]._147h8yxs,
.hero-banner button[data-hero-next]._147h8yxs {
  --hero-nav-size: clamp(34px, 2.8vw, 44px);
  position: absolute;
  top: 50%;
  z-index: 13;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: var(--hero-nav-size);
  min-width: var(--hero-nav-size);
  max-width: var(--hero-nav-size);
  height: var(--hero-nav-size);
  min-height: var(--hero-nav-size);
  max-height: var(--hero-nav-size);
  padding: 0;
  margin: 0;
  border-radius: 999rem;
  border: .125rem solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.10);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
  -webkit-backdrop-filter: blur(8px) saturate(130%);
  backdrop-filter: blur(8px) saturate(130%);
  opacity: .96;
  pointer-events: auto;
  transform: translate3d(0, -50%, 0);
  transition: opacity .16s ease, background-color .16s ease, border-color .16s ease, transform .16s ease;
}

.hero-banner button[data-hero-prev] {
  inset-inline-start: clamp(12px, 2.4vw, 34px);
  inset-inline-end: auto;
}

.hero-banner button[data-hero-next] {
  inset-inline-start: auto;
  inset-inline-end: clamp(12px, 2.4vw, 34px);
}

.hero-banner button[data-hero-prev]:hover,
.hero-banner button[data-hero-next]:hover,
.hero-banner button[data-hero-prev]:focus-visible,
.hero-banner button[data-hero-next]:focus-visible {
  background: rgba(255,255,255,.15);
  border-color: rgba(255,255,255,.18);
  opacity: 1;
  transform: translate3d(0, -50%, 0) scale(1.04);
}

.hero-banner button[data-hero-prev] > div,
.hero-banner button[data-hero-next] > div,
.hero-banner button[data-hero-prev] > div._1eu3eal36a,
.hero-banner button[data-hero-next] > div._1eu3eal36a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(20px, 1.55vw, 26px);
  height: clamp(20px, 1.55vw, 26px);
  color: inherit;
  pointer-events: none;
}

.hero-banner button[data-hero-prev] svg,
.hero-banner button[data-hero-next] svg {
  display: block;
  width: 100%;
  height: 100%;
  fill: currentColor;
}

@media (max-width: 767px) {
  .hero-banner button[data-hero-prev],
  .hero-banner button[data-hero-next],
  .hero-banner button[data-hero-prev]._1eu3eal36a,
  .hero-banner button[data-hero-next]._1eu3eal36a,
  .hero-banner button[data-hero-prev]._147h8yxs,
  .hero-banner button[data-hero-next]._147h8yxs {
    --hero-nav-size: 34px;
    opacity: .96;
  }

  .hero-banner button[data-hero-prev] {
    inset-inline-start: clamp(10px, 3vw, 18px);
  }

  .hero-banner button[data-hero-next] {
    inset-inline-end: clamp(10px, 3vw, 18px);
  }

  .hero-banner button[data-hero-prev] > div,
  .hero-banner button[data-hero-next] > div,
  .hero-banner button[data-hero-prev] > div._1eu3eal36a,
  .hero-banner button[data-hero-next] > div._1eu3eal36a {
    width: 21px;
    height: 21px;
  }
}

/* === 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 overrides */
: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. */
.hero-banner-stage,
.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,
.hero-banner button[data-hero-prev].sjyt1d3,
.hero-banner button[data-hero-next].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,
.hero-banner button[data-hero-prev].sjyt1d9::before,
.hero-banner button[data-hero-next].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,
  .hero-banner button[data-hero-prev].sjyt1d3,
  .hero-banner button[data-hero-next].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;
  }
}

/* Hero visibility still follows existing JS, but placement stays left/right. */
.hero-banner[data-hero-controls="hidden"] .hero-controls.rtpx-slider-controls {
  opacity: 0;
  pointer-events: none;
}
.hero-banner[data-hero-controls="visible"] .hero-controls.rtpx-slider-controls,
.hero-banner.is-banner-interacted .hero-controls.rtpx-slider-controls {
  opacity: 1;
  pointer-events: none;
}
.hero-banner[data-hero-controls="visible"] .hero-controls.rtpx-slider-controls > button,
.hero-banner.is-banner-interacted .hero-controls.rtpx-slider-controls > button {
  pointer-events: auto;
}

/* 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):not([data-hero-prev]):not([data-hero-next]) {
    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;
  }
}

/* === jackpot.css === */
html.page-transition-out body {
  opacity: .66;
  transform: translate3d(0, 3px, 0);
  transition: opacity .09s ease, transform .09s ease;
}

.spotlight-card-hit {
  cursor: pointer;
  text-decoration: none;
}

.spotlight-card-hit:focus-visible {
  outline: 0;
  box-shadow: var(--focus-ring);
}

.jackpot-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 90;
  height: var(--header-h);
  border-bottom: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255,255,255,.105), rgba(255,255,255,.045)),
    color-mix(in srgb, var(--bg) 76%, transparent);
  box-shadow: 0 14px 42px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.09);
  backdrop-filter: blur(20px) saturate(168%);
  -webkit-backdrop-filter: blur(20px) saturate(168%);
}

.jackpot-header-shell {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(16px, 2.2vw, 36px);
  width: 100%;
  height: 100%;
  padding-inline: max(clamp(14px, 2vw, 34px), env(safe-area-inset-left));
}

.jackpot-brand {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  width: clamp(116px, 10vw, 150px);
}

.jackpot-brand img {
  width: 100%;
  height: auto;
  object-fit: var(--game-card-media-fit, cover);
  object-position: left center;
  filter: drop-shadow(0 7px 14px rgba(0,0,0,.22));
}

.jackpot-nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(8px, 1vw, 18px);
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}

.jackpot-nav-links a,
.jackpot-header-action {
  transition: color .15s ease, border-color .15s ease, background-color .15s ease;
}

.jackpot-nav-links a:hover,
.jackpot-nav-links a:focus-visible {
  color: var(--text);
}

.jackpot-header-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 32%, transparent);
  border-radius: 999px;
  color: var(--accent-contrast);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 70%, #fff 8%), color-mix(in srgb, var(--accent) 60%, #101014 14%));
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .02em;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18), 0 10px 22px rgba(0,0,0,.18);
}

.jackpot-page {
  min-height: 100dvh;
  padding-top: 0;
}

.jackpot-main {
  position: relative;
  isolation: isolate;
  min-height: 100dvh;
  padding-top: calc(var(--header-h) + clamp(14px, 2.8vw, 34px));
  padding-bottom: clamp(34px, 5vw, 64px);
  overflow: hidden;
  animation: jackpot-enter .28s ease both;
}

.jackpot-backdrop {
  position: fixed;
  inset: 0;
  z-index: -2;
  width: 100%;
  height: 100svh;
  object-fit: cover;
  object-position: center top;
  opacity: .18;
  filter: blur(16px) saturate(1.05);
  transform: scale(1.035);
  mask-image: linear-gradient(black 0%, black 48%, transparent 100%);
  -webkit-mask-image: linear-gradient(black 0%, black 48%, transparent 100%);
  pointer-events: none;
}

.jackpot-main::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

.jackpot-shell {
  width: min(60rem, calc(100% - 32px));
  margin-inline: auto;
}

.jackpot-article {
  display: grid;
  gap: clamp(14px, 2.2vw, 24px);
}

.jackpot-heading {
  display: grid;
  gap: 10px;
}

.jackpot-meta-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.jackpot-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  width: fit-content;
  padding: 0 11px;
  border: 1px solid color-mix(in srgb, var(--text) 11%, transparent);
  border-radius: 999px;
  color: var(--muted);
  background: color-mix(in srgb, var(--surface-2) 74%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.065);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .045em;
  text-transform: uppercase;
}

.jackpot-title {
  max-width: 900px;
  margin: 0;
  color: var(--text);
  font-size: clamp(30px, 4.8vw, 58px);
  line-height: 1.02;
  letter-spacing: -.04em;
  text-wrap: balance;
}

.jyny5z2.jyny5z1.jyny5z3.jackpot-hero-media,
.jackpot-hero-media {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: var(--jackpot-media-ratio, 16 / 9);
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: clamp(20px, 3vw, 32px);
  background: color-mix(in srgb, var(--surface-solid) 86%, transparent);
  box-shadow: 0 22px 56px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.07);
}

.jackpot-hero-media img,
.jackpot-content-media img,
._1eu3ealo2._1eu3ealou._1eu3ealwq._1eu3eal3d._1eu3eal3k._14s22vd0._14s22vd3._14s22vd6 {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.jackpot-content {
  display: grid;
  gap: 13px;
  width: min(820px, 100%);
  margin-inline: auto;
  color: var(--muted);
  font-size: clamp(13px, 1.15vw, 16px);
  line-height: 1.55;
}

.jackpot-content h2 {
  margin: 8px 0 0;
  color: var(--text);
  font-size: clamp(22px, 2.7vw, 36px);
  line-height: 1.04;
  letter-spacing: -.035em;
}

.jackpot-content p {
  margin: 0;
}

.jackpot-content > p[data-jackpot-intro] {
  max-width: 76ch;
  margin-inline: auto;
  text-align: left;
}

.jackpot-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
  margin: 0;
}

.jackpot-detail-item {
  display: grid;
  align-content: center;
  min-height: 62px;
  padding: 11px 12px;
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 16px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 78%, transparent), color-mix(in srgb, var(--surface-2) 68%, transparent));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.055);
}

.jackpot-detail-item--wide {
  grid-column: 1 / -1;
}

.jackpot-detail-label {
  display: block;
  margin-bottom: 4px;
  color: var(--subtle);
  font-size: 9.5px;
  font-weight: 900;
  letter-spacing: .045em;
  text-transform: uppercase;
}

.jackpot-detail-value {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 850;
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.jackpot-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
}

.jackpot-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 13px;
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-2) 76%, transparent);
  color: var(--text);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .015em;
  line-height: 1.12;
  text-align: center;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 9px 18px rgba(0,0,0,.16);
}

.jackpot-button--primary {
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 70%, #fff 8%), color-mix(in srgb, var(--accent) 60%, #101014 14%));
  color: var(--accent-contrast);
}

.jackpot-button--proof {
  border-color: color-mix(in srgb, var(--accent) 28%, transparent);
  color: color-mix(in srgb, var(--accent) 82%, #fff 18%);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent) 14%, transparent),
    color-mix(in srgb, var(--surface-2) 86%, transparent));
}

.transfer-dialog {
  width: min(486px, calc(100vw - 28px));
  max-width: 486px;
  max-height: min(864px, calc(100dvh - 28px));
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  border-radius: clamp(20px, 4vw, 30px);
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 82%, transparent);
  box-shadow: 0 28px 80px rgba(0,0,0,.46), inset 0 1px 0 rgba(255,255,255,.08);
  overflow: hidden;
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
}

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

.transfer-dialog-shell {
  position: relative;
  display: grid;
  width: 100%;
  max-height: min(864px, calc(100dvh - 28px));
  overflow: auto;
  scrollbar-width: none;
}

.transfer-dialog-shell::-webkit-scrollbar {
  display: none;
}

.transfer-dialog-close {
  position: absolute;
  z-index: 2;
  top: 12px;
  right: 12px;
  display: inline-grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 78%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 24px rgba(0,0,0,.24);
  cursor: pointer;
  font-size: 26px;
  font-weight: 400;
  line-height: 1;
}

.transfer-proof-frame {
  position: relative;
  display: block;
  width: 100%;
  margin: 0;
  aspect-ratio: 9 / 16;
  background: color-mix(in srgb, var(--surface-2) 86%, #101014 14%);
}

.transfer-proof-frame img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.transfer-proof-caption {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  display: grid;
  gap: 3px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: 18px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 72%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
}

.transfer-proof-caption span {
  font-size: 14px;
  font-weight: 950;
  line-height: 1.1;
}

.transfer-proof-caption small {
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.25;
}

.jackpot-related,
.jackpot-top20 {
  display: grid;
  gap: 14px;
  margin-top: clamp(20px, 3.8vw, 44px);
}

.jackpot-top20[hidden] {
  display: none;
}

.jackpot-related-head,
.jackpot-top20-head {
  margin: 0;
}

.jackpot-related-head h2,
.jackpot-top20-head h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(25px, 3.6vw, 46px);
  line-height: .98;
  letter-spacing: -.045em;
}

.jackpot-related-stage,
.jackpot-top20-stage {
  --content-row-control-y: var(--rail-control-fallback-y, 56px);
  --featured-card-width: clamp(154px, 14.25vw, 204px);
  --control-y: var(--content-row-control-y);
}

.jackpot-rail-card {
  grid-template-rows: auto minmax(24px, auto) auto auto;
  color: inherit;
}

.jackpot-rail-card .game-card-hit,
.jackpot-rail-card .game-cover,
.jackpot-rail-card .game-cover-frame {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
  border: 0;
  background: transparent;
  box-shadow: none;
  outline: 0;
}

.jackpot-rail-card .game-card-hit {
  display: block;
}

.jackpot-rail-card .game-cover,
.jackpot-rail-card .game-cover-frame {
  width: 100%;
}

.jackpot-rail-card .game-cover img {
  width: 100%;
  height: 100%;
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
  object-fit: var(--game-card-media-fit, cover);
  object-position: center;
  background: transparent;
}

.jackpot-rail-card.has-natural-media-ratio .game-card-hit,
.jackpot-rail-card.has-natural-media-ratio .game-cover,
.jackpot-rail-card.has-natural-media-ratio .game-cover-frame {
  aspect-ratio: var(--game-card-media-ratio, 1 / 1);
}

.jackpot-rail-card .game-title-wrap {
  display: none;
}

.jackpot-game-link,
.jackpot-rail-card .game-title-link {
  color: inherit;
  cursor: pointer;
  text-decoration: none;
}

@keyframes jackpot-enter {
  from {
    opacity: .01;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (max-width: 720px) {
  .jackpot-header-shell {
    grid-template-columns: auto 1fr;
    padding-inline: 12px;
  }

  .jackpot-nav-links {
    display: none;
  }

  .jackpot-header-action {
    min-height: 32px;
    padding-inline: 10px;
    font-size: 10px;
  }

  .jackpot-main {
    padding-top: calc(var(--header-h) + 10px);
    padding-bottom: 46px;
  }

  .jackpot-shell {
    width: min(100% - 20px, 60rem);
  }

  .jackpot-article {
    gap: 11px;
  }

  .jackpot-heading {
    gap: 7px;
  }

  .jackpot-pill {
    min-height: 22px;
    padding-inline: 8px;
    font-size: 8px;
    letter-spacing: .035em;
  }

  .jackpot-title {
    max-width: 900px;
    margin: 0;
    color: var(--text);
    font-size: clamp(27px, 8.8vw, 42px);
    line-height: 1.02;
    letter-spacing: -.04em;
    text-wrap: balance;
  }

  .jackpot-content {
    gap: 11px;
    font-size: 13px;
    line-height: 1.48;
  }

  .jackpot-content h2 {
    margin-top: 4px;
    font-size: clamp(21px, 7vw, 30px);
  }

  .jackpot-detail-grid {
    gap: 8px;
  }

  .jackpot-detail-item {
    min-height: 58px;
    padding: 10px 11px;
    border-radius: 15px;
  }

  .jackpot-detail-label {
    margin-bottom: 3px;
    font-size: 8.5px;
    letter-spacing: .04em;
  }

  .jackpot-detail-value {
    font-size: 12px;
    line-height: 1.16;
  }

  .jackpot-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .jackpot-button {
    width: 100%;
    min-height: 34px;
    padding-inline: 10px;
    font-size: 9.5px;
  }

  .jackpot-button--video {
    grid-column: 1 / -1;
  }
}

@media (max-width: 380px) {
  .transfer-dialog {
    width: min(292px, calc(100vw - 52px));
    max-height: min(76dvh, 560px);
    border-radius: 18px;
  }

  .transfer-dialog-shell,
  .transfer-proof-frame {
    max-height: min(76dvh, 560px);
  }
}

@media (max-width: 360px) {
  .jackpot-shell {
    width: min(100% - 16px, 60rem);
  }

  .jackpot-detail-grid {
    gap: 6px;
  }

  .jackpot-detail-item {
    min-height: 54px;
    padding: 9px 8px;
  }

  .jackpot-detail-value {
    font-size: 11px;
  }

  .jackpot-actions {
    gap: 6px;
  }

  .jackpot-button {
    min-height: 32px;
    padding-inline: 8px;
    font-size: 8.75px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .jackpot-main {
    animation: none;
  }

  html.page-transition-out body {
    transition: none;
    transform: none;
  }
}

.jackpot-related.api-spotlight-section {
  overflow: visible;
  contain: layout;
}

.jackpot-related-stage.api-spotlight-stage {
  --news-control-y: clamp(122px, 16.5vw, 178px);
  --content-row-control-y: var(--news-control-y);
  --control-y: var(--news-control-y);
}

.jackpot-related-rail.api-spotlight-rail {
  gap: clamp(16px, 1.55vw, 22px);
  padding-top: 10px;
  padding-bottom: 18px;
}

.jackpot-related .jackpot-win-card {
  flex: 0 0 clamp(312px, 40vw, 529px);
  width: clamp(312px, 40vw, 529px);
  min-width: clamp(312px, 40vw, 529px);
}

.jackpot-related .jackpot-win-card .win-proof-media {
  aspect-ratio: 16 / 9;
}

.jackpot-related .jackpot-win-card .win-proof-media img {
  object-fit: var(--game-card-media-fit, cover);
  object-position: center;
}

.jackpot-related .jackpot-win-card .spotlight-card-body {
  min-height: 132px;
}



.jackpot-rail-card .game-title-wrap,
.jackpot-rail-card .game-card-actions {
  position: relative;
  z-index: 1;
}

@media (max-width: 700px) {
  .jackpot-related-stage.api-spotlight-stage {
    --news-control-y: var(--rail-control-fallback-y, 112px);
    --content-row-control-y: var(--news-control-y);
    --control-y: var(--news-control-y);
  }

  .jackpot-related-rail.api-spotlight-rail {
    gap: 12px;
    padding-top: 6px;
    padding-bottom: 12px;
  }

  .jackpot-related .jackpot-win-card {
    flex-basis: clamp(264px, 86vw, 360px);
    width: clamp(264px, 86vw, 360px);
    min-width: clamp(264px, 86vw, 360px);
  }

  .jackpot-related .jackpot-win-card .spotlight-card-body {
    min-height: 112px;
  }
}

.jackpot-related-rail > *,
.jackpot-top20-rail > *,
.jackpot-rail-card,
.jackpot-related-rail .api-spotlight-card,
.jackpot-related-rail .news-card {
  overflow: visible;
  contain: none;
}

.jackpot-rail-card:hover,
.jackpot-rail-card:focus-within,
.jackpot-related-rail .api-spotlight-card:hover,
.jackpot-related-rail .api-spotlight-card:focus-within {
  z-index: 12;
}


.jackpot-button--video {
  border-color: color-mix(in srgb, var(--accent-2) 34%, transparent);
  color: color-mix(in srgb, var(--accent-2) 86%, #fff 14%);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent-2) 16%, transparent),
    color-mix(in srgb, var(--surface-2) 88%, transparent));
}

.jackpot-button--video[hidden] {
  display: none !important;
}

.victory-video-dialog {
  width: min(860px, calc(100vw - 36px));
  max-width: 860px;
  max-height: calc(100dvh - 36px);
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  border-radius: clamp(22px, 3vw, 34px);
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 88%, transparent);
  box-shadow: 0 30px 90px rgba(0,0,0,.50), inset 0 1px 0 rgba(255,255,255,.08);
  overflow: hidden;
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
}

.victory-video-dialog::backdrop {
  background: rgba(0,0,0,.68);
  backdrop-filter: blur(9px);
  -webkit-backdrop-filter: blur(9px);
}

.victory-video-shell {
  display: grid;
  gap: 0;
  width: 100%;
}

.victory-video-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--surface) 82%, transparent),
    color-mix(in srgb, var(--surface-2) 76%, transparent));
}

.victory-video-head > div {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.victory-video-kicker {
  color: color-mix(in srgb, var(--accent) 84%, #fff 16%);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.victory-video-head strong {
  color: var(--text);
  font-size: clamp(16px, 1.8vw, 22px);
  font-weight: 950;
  line-height: 1.05;
}

.victory-video-head small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
}

.victory-video-close {
  display: inline-grid;
  flex: 0 0 auto;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid color-mix(in srgb, var(--text) 18%, transparent);
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-solid) 78%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 10px 24px rgba(0,0,0,.24);
  cursor: pointer;
  font-size: 26px;
  font-weight: 400;
  line-height: 1;
}

.victory-video-frame {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: #000;
}

.victory-video-frame video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #000;
}

@media (max-width: 640px) {
  .victory-video-dialog {
    width: min(100vw - 18px, 460px);
    max-width: calc(100vw - 18px);
    max-height: calc(100dvh - 18px);
    margin: auto auto 9px;
    border-radius: 24px 24px 20px 20px;
  }

  .victory-video-head {
    padding: 14px;
  }

  .victory-video-dialog.is-mobile-mode .victory-video-frame {
    aspect-ratio: 9 / 16;
    max-height: calc(100dvh - 132px);
  }

  .victory-video-dialog.is-desktop-mode .victory-video-frame {
    aspect-ratio: 16 / 9;
  }

  .victory-video-frame video {
    object-fit: contain;
  }
}

.victory-video-dialog.is-desktop-mode {
  width: min(860px, calc(100vw - 36px));
  max-width: 860px;
}

.victory-video-dialog.is-mobile-mode {
  width: min(430px, calc(100vw - 24px));
  max-width: 430px;
}

.victory-video-dialog.is-desktop-mode .victory-video-frame {
  aspect-ratio: 16 / 9;
  max-height: calc(100dvh - 150px);
}

.victory-video-dialog.is-mobile-mode .victory-video-frame {
  aspect-ratio: 9 / 16;
  max-height: calc(100dvh - 132px);
}

.victory-video-dialog.is-mobile-mode .victory-video-shell {
  max-height: calc(100dvh - 24px);
}

/* Neutral 404 page. */
.not-found-page {
  min-height: 100dvh;
}

.not-found-main {
  min-height: 100dvh;
  display: grid;
  place-items: center;
  width: min(100% - 32px, 760px);
  margin-inline: auto;
  padding-block: clamp(64px, 12vw, 120px);
}

.not-found-card {
  display: grid;
  gap: 14px;
  width: 100%;
  padding: clamp(22px, 4vw, 40px);
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: clamp(18px, 2.4vw, 28px);
  color: var(--text);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--surface) 90%, transparent),
    color-mix(in srgb, var(--surface-2) 82%, transparent));
  box-shadow: 0 18px 48px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.07);
}

.not-found-code {
  margin: 0;
  color: color-mix(in srgb, var(--accent) 76%, #fff 24%);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.not-found-card h1 {
  margin: 0;
  color: var(--text);
  font-size: clamp(28px, 4.5vw, 48px);
  line-height: 1;
  letter-spacing: -.04em;
}

.not-found-card p:not(.not-found-code) {
  max-width: 52ch;
  margin: 0;
  color: var(--muted);
  font-size: clamp(14px, 1.5vw, 17px);
  line-height: 1.55;
}

.not-found-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 34%, transparent);
  border-radius: 999px;
  color: var(--accent-contrast);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 72%, #fff 8%), color-mix(in srgb, var(--accent) 62%, #101014 14%));
  font-size: 12px;
  font-weight: 950;
  text-decoration: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.16), 0 10px 22px rgba(0,0,0,.20);
}

@media (max-width: 720px) {
  .not-found-main {
    width: min(100% - 24px, 760px);
    padding-block: 56px;
  }

  .not-found-card {
    gap: 12px;
    border-radius: 20px;
  }

  .not-found-button {
    min-height: 36px;
    padding-inline: 14px;
    font-size: 11px;
  }

  .jackpot-content > p[data-jackpot-intro] {
    max-width: 100%;
  }}

/* === game-pola.css === */
.game-pola-page {
  min-height: 100vh;
  color: var(--text, #f8f8fa);
}

.game-pola-page.game-pola-page::before,
.game-pola-page.game-pola-page::after,
.game-pola-page .game-pola-main::before,
.game-pola-page .game-pola-main::after {
  content: none;
  display: none;
}

.game-pola-main {
  padding-top: clamp(12px, 2vw, 22px);
  padding-bottom: clamp(36px, 6vw, 72px);
}

.game-pola-shell {
  width: min(1160px, calc(100% - 32px));
  margin-inline: auto;
}

.game-pola-intro {
  display: grid;
  gap: 10px;
  max-width: 980px;
  margin: 0 0 clamp(10px, 1.7vw, 16px);
}

.game-pola-intro-chips {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.game-pola-intro-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 27px;
  padding: 6px 11px;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 999px;
  background: rgba(255, 255, 255, .06);
  color: rgba(236, 244, 255, .90);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .015em;
  line-height: 1;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .07);
}

.game-pola-intro-chip--provider {
  border-color: rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .045);
  color: rgba(226, 232, 240, .84);
}

.game-pola-intro h2 {
  max-width: 980px;
  margin: 0;
  color: #fff;
  font-size: clamp(28px, 3.8vw, 48px);
  line-height: 1.04;
  letter-spacing: -.052em;
  font-weight: 950;
  text-wrap: balance;
}

.game-pola-hero {
  position: relative;
  min-height: clamp(500px, 60vw, 680px);
  border-radius: clamp(20px, 3vw, 34px);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .12);
  background: #15161d;
}

.game-pola-backdrop {
  position: absolute;
  inset: 0;
  background-image: var(--pola-bg, linear-gradient(135deg, rgba(38,187,255,.22), rgba(17,19,27,.95)));
  background-size: cover;
  background-position: center;
  opacity: .46;
}

.game-pola-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11, 12, 18, .97) 0%, rgba(11, 12, 18, .82) 46%, rgba(11, 12, 18, .32) 100%),
    linear-gradient(0deg, rgba(11, 12, 18, .95), rgba(11, 12, 18, .10) 55%, rgba(11, 12, 18, .42));
  pointer-events: none;
}

.game-pola-hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 420px);
  gap: clamp(20px, 4vw, 46px);
  min-height: inherit;
  padding: clamp(22px, 5vw, 54px);
  align-items: end;
}

.game-pola-copy {
  min-width: 0;
  max-width: min(100%, 760px);
}


.game-pola-kicker,
.game-pola-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 26px;
  padding: 5px 10px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .08);
  color: rgba(248, 250, 252, .86);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.game-pola-title {
  margin: 18px 0 18px;
  max-width: 760px;
  font-size: clamp(40px, 7.4vw, 88px);
  line-height: .92;
  letter-spacing: -.07em;
  font-weight: 950;
  color: #fff;
  overflow-wrap: anywhere;
}

.game-pola-subtitle {
  max-width: 560px;
  margin: 0;
  color: rgba(226, 232, 240, .78);
  font-size: clamp(13px, 1.7vw, 16px);
  line-height: 1.65;
  overflow-wrap: anywhere;
}

.game-pola-meta-row {
  display: none;
}

.game-pola-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 26px;
}

.game-pola-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 999px;
  background: rgba(255, 255, 255, .10);
  color: #fff;
  text-decoration: none;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .04em;
  text-transform: uppercase;
  outline: 0 solid transparent;
  outline-offset: .56rem;
  will-change: transform;
  transition:
    transform .16s ease,
    background-color .16s ease,
    border-color .16s ease,
    color .16s ease,
    opacity .16s ease,
    outline-color .16s ease,
    outline-offset .16s ease,
    outline-width .16s ease;
}

.game-pola-button:hover,
.game-pola-button:focus-visible {
  background: rgba(255, 255, 255, .16);
  border-color: rgba(255, 255, 255, .26);
  outline-color: rgba(255, 255, 255, .16);
  outline-offset: .18rem;
  outline-width: .18rem;
  transform: translate3d(0, -1px, 0) scale(1.01);
}

.game-pola-button:active {
  outline-offset: .12rem;
  outline-width: .12rem;
  transform: translate3d(0, 0, 0) scale(.99);
}

.game-pola-button--primary {
  min-width: 158px;
  min-height: 46px;
  padding: 0 20px;
  border: 1px solid color-mix(in srgb, var(--accent, #d7d7dc) 58%, transparent);
  border-radius: 10px;
  color: #f8f8fa;
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-2, #c7c7cc) 88%, #2a2a30 12%), color-mix(in srgb, var(--accent, #d7d7dc) 62%, #101014 38%));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .22);
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle, .625rem);
  outline-style: solid;
  outline-width: 0;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: -.01em;
  line-height: 1;
  text-transform: uppercase;
  transition: outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out, transform .15s ease-out, border-color .15s ease-out, background-color .15s ease-out;
}

.game-pola-button--primary:hover,
.game-pola-button--primary:focus-visible {
  color: #f8f8fa;
  border-color: color-mix(in srgb, var(--accent, #d7d7dc) 72%, transparent);
  outline-color: rgba(255, 255, 255, .28);
  outline-offset: var(--carousel-outline-active, .1875rem);
  outline-width: var(--carousel-outline-active, .1875rem);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent-2, #c7c7cc) 92%, #2a2a30 8%), color-mix(in srgb, var(--accent, #d7d7dc) 68%, #101014 32%));
  transform: translateY(-.125rem);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .24);
}


.game-pola-icon-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 10px;
  color: rgba(248, 250, 252, .92);
  background: rgba(255, 255, 255, .10);
  cursor: pointer;
  outline: 0 solid transparent;
  outline-offset: .56rem;
  transition: transform .15s ease-out, border-color .15s ease-out, background-color .15s ease-out, color .15s ease-out, outline-color .15s ease-out, outline-offset .15s ease-out, outline-width .15s ease-out;
}

.game-pola-icon-button svg {
  display: block;
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.game-pola-icon-button:hover,
.game-pola-icon-button:focus-visible {
  color: #fff;
  border-color: rgba(255, 255, 255, .28);
  background: rgba(255, 255, 255, .16);
  outline-color: rgba(255, 255, 255, .18);
  outline-offset: .18rem;
  outline-width: .18rem;
  transform: translateY(-.125rem);
}

.game-pola-icon-button:active {
  transform: translateY(0) scale(.98);
}

.game-pola-icon-button.is-active,
.game-pola-icon-button[aria-pressed="true"] {
  color: #f8f8fa;
  border-color: color-mix(in srgb, var(--accent, #d7d7dc) 58%, transparent);
  background: linear-gradient(135deg, rgba(14, 165, 233, .78), rgba(37, 99, 235, .72));
}

.game-pola-button.is-disabled {
  opacity: .42;
  pointer-events: none;
}

.game-pola-side-card {
  align-self: end;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 26px;
  background: rgba(17, 19, 27, .88);
  overflow: hidden;
}

.game-pola-cover {
  aspect-ratio: 16 / 10;
  background: rgba(255, 255, 255, .06);
}

.game-pola-cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.game-pola-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 14px;
}

.game-pola-stat {
  display: flex;
  min-width: 0;
  min-height: 104px;
  flex-direction: column;
  justify-content: flex-start;
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .075), rgba(255, 255, 255, .035)),
    rgba(11, 15, 24, .46);
  padding: 13px;
}

.game-pola-stat > span {
  display: block;
  color: rgba(226, 232, 240, .64);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .065em;
}

.game-pola-stat strong {
  display: inline-flex;
  align-items: center;
  gap: 13px;
  width: 100%;
  margin-top: 12px;
  color: #fff;
  font-size: clamp(30px, 4vw, 44px);
  line-height: .92;
  letter-spacing: -.05em;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.game-pola-stat--progress strong {
  color: #fff;
}

.game-pola-progress-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  border-radius: 0;
  color: rgba(248, 250, 252, .96);
  background: transparent;
}

.game-pola-progress-icon svg {
  display: block;
  width: 44px;
  height: 44px;
  fill: currentColor;
}

.game-pola-stat--progress [data-pola-score] {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  color: #fff;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  text-transform: none;
}

.game-pola-stat--progress[data-progress-tier] strong {
  color: #fff;
}



.game-pola-stat--progress strong,
.game-pola-stat--online strong {
  min-width: 0;
}

.game-pola-section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
  margin-top: 18px;
}

.game-pola-panel {
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 26px;
  background: rgba(21, 23, 32, .78);
  padding: clamp(18px, 3vw, 26px);
}

.game-pola-panel h2,
.game-pola-panel h3 {
  margin: 0;
  color: #fff;
  letter-spacing: -.03em;
}

.game-pola-panel p {
  color: rgba(226, 232, 240, .76);
  line-height: 1.65;
}

.game-pola-pattern-list {
  display: grid;
  gap: 12px;
  margin-top: 18px;
}

.game-pola-pattern-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: center;
  min-height: 78px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .055);
}

.game-pola-pattern-card small {
  display: block;
  color: rgba(226, 232, 240, .62);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .04em;
}

.game-pola-pattern-card strong {
  display: block;
  margin-top: 5px;
  color: #fff;
  font-size: clamp(15px, 2.2vw, 18px);
  line-height: 1.25;
}

.game-pola-pattern-card span {
  color: rgba(226, 232, 240, .78);
  font-size: 12px;
  font-weight: 800;
}

.game-pola-empty,
.game-pola-loading {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, .06);
  color: rgba(226, 232, 240, .74);
  font-weight: 800;
}

@media (max-width: 860px) {
  .game-pola-main {
    padding-top: 12px;
  }

  .game-pola-shell {
    width: min(100% - 28px, 1160px);
  }

  .game-pola-hero {
    min-height: auto;
    border-radius: 20px;
  }

  .game-pola-hero::after {
    background:
      linear-gradient(180deg, rgba(11, 12, 18, .96) 0%, rgba(11, 12, 18, .78) 48%, rgba(11, 12, 18, .96) 100%),
      linear-gradient(0deg, rgba(11, 12, 18, .82), rgba(11, 12, 18, .18));
  }

  .game-pola-hero-grid {
    grid-template-columns: minmax(0, 1fr);
    gap: 16px;
    padding: 18px;
    align-items: start;
  }

  .game-pola-copy,
  .game-pola-side-card,
  .game-pola-stat--progress strong,
  .game-pola-stat--online strong {
    min-width: 0;
  }

  .game-pola-copy,
  .game-pola-side-card {
    width: 100%;
  }

  .game-pola-section-grid {
    grid-template-columns: 1fr;
  }

  .game-pola-side-card {
    align-self: stretch;
    justify-self: stretch;
    max-width: min(100%, 480px);
    margin-inline: auto;
    border-radius: 20px;
  }

  .game-pola-title {
    margin-block: 12px;
    font-size: clamp(32px, 11.4vw, 54px);
    line-height: .96;
  }

  .game-pola-subtitle {
    max-width: 100%;
    font-size: 13px;
    line-height: 1.5;
  }

  .game-pola-actions {
    gap: 8px;
    margin-top: 18px;
  }

  .game-pola-button--primary {
    flex: 1 1 auto;
    min-width: 0;
    min-height: 42px;
    border-radius: 10px;
  }

  .game-pola-icon-button {
    width: 42px;
    height: 42px;
    border-radius: 10px;
  }
}

.game-pola-section-grid--split {
  grid-template-columns: minmax(320px, .88fr) minmax(0, 1.12fr);
  align-items: stretch;
}

.game-pola-section-grid--split > .game-pola-panel {
  display: flex;
  flex-direction: column;
  min-height: 320px;
}

.game-pola-section-grid--split .game-pola-pattern-list,
.game-pola-section-grid--split .game-pola-table-wrap {
  flex: 1;
}

.game-pola-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.game-pola-panel-tag {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 9px;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 999px;
  background: rgba(255, 255, 255, .06);
  color: rgba(226, 232, 240, .72);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  white-space: nowrap;
}

.game-pola-full-panel {
  overflow: hidden;
}

.game-pola-table-wrap {
  width: 100%;
  margin-top: 18px;
  overflow: visible;
}

.game-pola-full-list {
  display: grid;
  gap: 12px;
}

.game-pola-full-card {
  border: 1px solid rgba(255, 255, 255, .10);
  border-radius: 20px;
  background: rgba(255, 255, 255, .05);
  padding: 14px;
}

.game-pola-full-card h3 {
  margin: 0 0 12px;
  color: #fff;
  font-size: 14px;
  font-weight: 950;
  letter-spacing: -.02em;
}

.game-pola-full-card dl {
  display: grid;
  gap: 8px;
  margin: 0;
}

.game-pola-full-card dl > div {
  display: grid;
  grid-template-columns: minmax(118px, .52fr) minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 9px 0;
  border-top: 1px solid rgba(255, 255, 255, .07);
}

.game-pola-full-card dt,
.game-pola-full-card dd {
  margin: 0;
  min-width: 0;
}

.game-pola-full-card dt {
  color: rgba(226, 232, 240, .58);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.game-pola-full-card dd {
  color: rgba(248, 250, 252, .94);
  font-size: 12px;
  font-weight: 820;
  line-height: 1.45;
  overflow-wrap: anywhere;
}


.game-pola-toast {
  position: fixed;
  z-index: 90;
  left: 50%;
  bottom: 24px;
  max-width: min(92vw, 420px);
  padding: 11px 14px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 999px;
  color: #f8f8fa;
  background: rgba(12, 14, 22, .92);
  box-shadow: 0 10px 28px rgba(0, 0, 0, .28);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.35;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, 10px, 0);
  transition: opacity .18s ease, transform .18s ease;
}

.game-pola-toast.is-visible {
  opacity: 1;
  transform: translate3d(-50%, 0, 0);
}

@media (max-width: 1100px) {
  .game-pola-section-grid--split {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .game-pola-panel-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .game-pola-full-card {
    padding: 13px;
    border-radius: 18px;
  }

  .game-pola-full-card dl > div {
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 10px;
  }
}



.game-pola-top20-section {
  margin-top: clamp(20px, 3vw, 34px);
  overflow: visible;
}

.game-pola-top20-section .section-title-link {
  width: 100%;
  min-width: 0;
}

.game-pola-top20-status {
  margin: 10px 0 0;
  color: rgba(226, 232, 240, .66);
  font-size: 12px;
  font-weight: 800;
}

.game-pola-top20-status[hidden] {
  display: none;
}

.game-pola-top20-status[data-state="error"] {
  color: rgba(254, 202, 202, .88);
}

.game-pola-top20-stage {
  margin-top: 4px;
}

.game-pola-top20-rail {
  min-height: calc(var(--featured-card-width, 196px) + 178px);
  contain: layout paint;
  content-visibility: auto;
  contain-intrinsic-size: 374px;
}

.game-pola-top20-rail.is-loading {
  opacity: .72;
}

.game-pola-top20-rail > .game-pola-empty {
  flex: 1 0 100%;
}

.game-pola-top-card.game-card {
  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);
}

.game-pola-top-card .game-card-shell {
  height: 100%;
}

@media (max-width: 860px) {
  .game-pola-section-grid--split > .game-pola-panel {
    min-height: 0;
  }
}

@media (max-width: 1100px) {
  .game-pola-section-grid--split > .game-pola-panel {
    min-height: 0;
  }
}

/* Player online chip + game-pola page controls */
.game-pola-stat {
  min-height: 104px;
}

.game-pola-stat--online {
  display: flex;
  min-width: 0;
  flex-direction: column;
  justify-content: flex-start;
}

.game-pola-stat--online strong {
  display: inline-flex;
  align-items: center;
  gap: 13px;
  width: 100%;
  margin-top: 12px;
  color: #fff;
  font-size: clamp(30px, 4vw, 44px);
  line-height: .92;
  letter-spacing: -.05em;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.game-pola-stat--online [data-pola-online-value] {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  color: #fff;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  text-transform: none;
}

.game-pola-online-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: currentColor;
}

.game-pola-online-icon {
  width: 44px;
  height: 44px;
  color: rgba(248, 250, 252, .96);
}

.game-pola-online-icon svg {
  display: block;
  width: 1em;
  height: 1em;
  fill: currentColor;
}

.game-pola-online-icon svg {
  width: 44px;
  height: 44px;
}

.game-pola-top20-stage {
  --control-y: calc(25px + ((var(--featured-card-width, 196px) - 14px) / 2));
  --content-row-control-y: var(--control-y);
  overflow: visible;
}

.game-pola-top20-stage .content-rail-button {
  z-index: 18;
  top: var(--control-y);
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-user-select: none;
  user-select: none;
}

.game-pola-top20-stage .content-rail-button[aria-disabled="true"],
.game-pola-top20-stage .content-rail-button:disabled {
  pointer-events: none;
}

.game-pola-top20-rail {
  scroll-snap-type: x proximity;
  overscroll-behavior-x: contain;
}

.game-pola-top20-rail > .game-card,
.game-pola-top20-rail > .feature-island-card {
  scroll-snap-align: start;
  scroll-snap-stop: normal;
}

@media (max-width: 620px) {
  .game-pola-side-card {
    max-width: 100%;
    border-radius: 18px;
  }

  .game-pola-stat-grid {
    gap: 8px;
    padding: 11px;
  }

  .game-pola-stat {
    min-height: 78px;
    padding: 11px;
    border-radius: 16px;
  }

  .game-pola-stat strong {
    gap: 8px;
    margin-top: 10px;
    font-size: clamp(24px, 8vw, 32px);
    letter-spacing: -.04em;
  }

  .game-pola-online-icon,
  .game-pola-progress-icon {
    width: 32px;
    height: 32px;
    flex-basis: 32px;
  }

  .game-pola-online-icon svg,
  .game-pola-progress-icon svg {
    width: 21px;
    height: 21px;
  }


  .game-pola-top20-stage {
    --control-y: calc(24px + ((var(--featured-card-width, 154px) - 14px) / 2));
  }
}



.game-pola-page .global-header-bg {
  background: linear-gradient(90deg, rgba(255,255,255,.032), transparent 48%, rgba(255,255,255,.026));
}

.game-pola-page .game-pola-main,
.game-pola-page .game-pola-shell {
  border-left: 0;
  box-shadow: none;
}

.game-pola-page .global-header {
  border-left: 0;
  box-shadow: 0 14px 42px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.08);
}

.game-pola-page .main-nav__list-item::before,
.game-pola-page .main-nav__list-item::after,
.game-pola-page .main-nav__link::before,
.game-pola-page .main-nav__link::after {
  box-shadow: none;
}

@media (max-width: 620px) {
  .game-pola-main {
    padding-top: 10px;
  }

  .game-pola-intro {
    gap: 8px;
    margin-bottom: 12px;
  }

  .game-pola-intro h2 {
    font-size: clamp(24px, 8vw, 34px);
    line-height: 1.06;
    letter-spacing: -.045em;
  }

  .game-pola-intro-chip {
    min-height: 25px;
    padding: 5px 9px;
    font-size: 10.5px;
  }
}

@media (max-width: 620px) {
  .game-pola-shell {
    width: min(100% - 24px, 1160px);
  }

  .game-pola-hero-grid {
    padding: 16px;
  }

  .game-pola-cover {
    aspect-ratio: 16 / 9;
  }

  .game-pola-stat-grid {
    grid-template-columns: 1fr;
  }

  .game-pola-stat {
    min-height: 74px;
  }

  .game-pola-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 42px 42px;
    width: 100%;
  }

  .game-pola-button--primary {
    width: 100%;
  }

  .game-pola-top20-section {
    margin-top: 18px;
  }

  .game-pola-top20-rail {
    min-height: calc(var(--featured-card-width, 154px) + 160px);
    contain-intrinsic-size: 314px;
  }
}

@media (max-width: 380px) {
  .game-pola-shell {
    width: min(100% - 18px, 1160px);
  }

  .game-pola-hero-grid,
  .game-pola-panel {
    padding: 14px;
  }

  .game-pola-title {
    font-size: clamp(29px, 10.8vw, 42px);
  }

  .game-pola-stat-grid {
    padding: 9px;
  }

  .game-pola-stat {
    padding: 10px;
  }

  .game-pola-stat strong {
    font-size: clamp(23px, 7.5vw, 29px);
  }
}

/* === promosi.css === */
.promo-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 90;
  height: var(--header-h);
  border-bottom: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255,255,255,.095), rgba(255,255,255,.038)),
    color-mix(in srgb, var(--bg) 82%, transparent);
  box-shadow: 0 14px 42px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(18px) saturate(158%);
  -webkit-backdrop-filter: blur(18px) saturate(158%);
}

.promo-header[data-scrolled] {
  border-bottom-color: color-mix(in srgb, var(--text) 16%, transparent);
  background:
    linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.044)),
    color-mix(in srgb, var(--bg) 88%, transparent);
}

.promo-header-shell {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(16px, 2.2vw, 36px);
  width: 100%;
  height: 100%;
  padding-inline: max(clamp(14px, 2vw, 34px), env(safe-area-inset-left));
}

.promo-brand {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  width: clamp(116px, 10vw, 150px);
  color: var(--text);
}

.promo-brand img {
  display: block;
  width: 100%;
  max-width: 150px;
  height: auto;
  max-height: 38px;
  object-fit: contain;
  object-position: left center;
  filter: drop-shadow(0 7px 14px rgba(0,0,0,.22));
}

.promo-header-links {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(8px, 1vw, 18px);
  min-width: 0;
  overflow: hidden;
}

.promo-header-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 0 clamp(9px, .8vw, 16px);
  border-radius: 12px;
  color: var(--muted);
  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;
}

.promo-header-links a:hover,
.promo-header-links a:focus-visible,
.promo-header-links a[aria-current="page"] {
  color: var(--text);
  background: color-mix(in srgb, var(--text) 7%, transparent);
}

.promo-header-action,
.promo-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: 999px;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), 0 12px 24px rgba(0,0,0,.18);
  transition: color .16s ease, border-color .16s ease, background-color .16s ease, transform .16s ease;
}

.promo-header-action {
  justify-self: end;
  min-height: 36px;
  padding: 0 14px;
  border-color: color-mix(in srgb, var(--accent) 32%, transparent);
  color: var(--accent-contrast);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 70%, #fff 8%), color-mix(in srgb, var(--accent) 60%, #101014 14%));
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .02em;
}

.promo-subnav {
  position: sticky;
  top: var(--header-h);
  z-index: 70;
  margin-top: var(--header-h);
  border-bottom: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  color: var(--text);
  background: color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter: blur(16px) saturate(150%);
  -webkit-backdrop-filter: blur(16px) saturate(150%);
}

.promo-subnav-shell {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(10px, 1.4vw, 22px);
  width: 100%;
  min-height: 46px;
  padding-inline: max(clamp(14px, 2vw, 34px), env(safe-area-inset-left));
  overflow-x: auto;
  scrollbar-width: none;
}

.promo-subnav-shell::-webkit-scrollbar {
  display: none;
}

.promo-subnav-label,
.promo-subnav a {
  flex: 0 0 auto;
  font-size: clamp(11px, .75vw, 13px);
  font-weight: 880;
  letter-spacing: -.01em;
  white-space: nowrap;
}

.promo-subnav-label {
  color: color-mix(in srgb, var(--text) 56%, transparent);
}

.promo-subnav a {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border-bottom: 2px solid transparent;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  text-decoration: none;
}

.promo-subnav a:hover,
.promo-subnav a:focus-visible,
.promo-subnav a[aria-current="page"] {
  border-bottom-color: color-mix(in srgb, var(--accent-2) 76%, transparent);
  color: var(--text);
}

.promo-page {
  min-height: 100dvh;
  padding-top: 0;
}

.promo-main {
  position: relative;
  isolation: isolate;
  min-height: calc(100dvh - var(--header-h));
  padding-bottom: clamp(34px, 5vw, 64px);
  animation: promo-enter .26s ease both;
}

.promo-shell {
  width: min(72rem, calc(100% - 32px));
  margin-inline: auto;
}

.promo-masthead {
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid color-mix(in srgb, var(--text) 8%, transparent);
}

.promo-masthead::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

.promo-masthead-inner {
  display: grid;
  gap: clamp(10px, 1.4vw, 16px);
  padding-block: clamp(28px, 4.2vw, 56px) clamp(24px, 3.8vw, 48px);
}

.promo-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  color: color-mix(in srgb, var(--text) 58%, transparent);
  font-size: 12px;
  font-weight: 760;
}

.promo-breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.promo-breadcrumb a:hover,
.promo-breadcrumb a:focus-visible {
  color: var(--text);
}

.promo-eyebrow,
.promo-card-kicker {
  margin: 0;
  color: color-mix(in srgb, var(--accent-2) 82%, var(--text));
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.promo-masthead h1 {
  max-width: 820px;
  margin: 0;
  color: var(--text);
  font-size: clamp(48px, 9vw, 112px);
  font-weight: 950;
  line-height: .9;
  letter-spacing: -.07em;
}

.promo-lead {
  max-width: 660px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(15px, 1.55vw, 20px);
  line-height: 1.55;
}

.promo-content {
  display: grid;
  gap: clamp(14px, 2.2vw, 22px);
  padding-top: clamp(24px, 3.5vw, 42px);
}

.promo-section-intro {
  display: grid;
  gap: 8px;
  max-width: 720px;
}

.promo-section-intro h2,
.promo-callout h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(28px, 4.4vw, 56px);
  line-height: .96;
  letter-spacing: -.055em;
}

.promo-section-intro p,
.promo-card p,
.promo-callout p {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}

.promo-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(12px, 1.8vw, 18px);
}

.promo-card {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 210px;
  padding: clamp(16px, 2vw, 22px);
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 24px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 84%, transparent), color-mix(in srgb, var(--surface-2) 74%, transparent));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 18px 42px rgba(0,0,0,.22);
}

.promo-card h3 {
  margin: 0;
  color: var(--text);
  font-size: clamp(20px, 2.3vw, 30px);
  line-height: 1;
  letter-spacing: -.04em;
}

.promo-card a {
  align-self: end;
  width: fit-content;
  margin-top: 4px;
  color: color-mix(in srgb, var(--text) 86%, transparent);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}

.promo-card a:hover,
.promo-card a:focus-visible {
  color: var(--text);
}

.promo-callout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(14px, 3vw, 30px);
  margin-top: clamp(22px, 3.8vw, 46px);
  padding: clamp(20px, 4vw, 38px);
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 28px;
  background:
    radial-gradient(circle at 14% 0%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 20rem),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 84%, transparent), color-mix(in srgb, var(--surface-2) 72%, transparent));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 20px 48px rgba(0,0,0,.24);
}

.promo-callout-copy {
  display: grid;
  gap: 10px;
  max-width: 720px;
}

.promo-callout-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.promo-button {
  min-height: 40px;
  padding: 0 15px;
  color: var(--text);
  background: color-mix(in srgb, var(--surface-2) 76%, transparent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .02em;
}

.promo-button--primary {
  border-color: color-mix(in srgb, var(--accent) 34%, transparent);
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent-2) 70%, #fff 8%), color-mix(in srgb, var(--accent) 60%, #101014 14%));
  color: var(--accent-contrast);
}

@keyframes promo-enter {
  from {
    opacity: .01;
    transform: translate3d(0, 8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@media (max-width: 980px) {
  .promo-header-shell {
    gap: 12px;
  }

  .promo-header-links {
    overflow-x: auto;
    scrollbar-width: none;
  }

  .promo-header-links::-webkit-scrollbar {
    display: none;
  }

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

  .promo-callout {
    grid-template-columns: 1fr;
  }

  .promo-callout-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .promo-header-shell {
    grid-template-columns: auto minmax(0, 1fr);
    padding-inline: 12px;
  }

  .promo-brand {
    width: 104px;
  }

  .promo-header-action {
    display: none;
  }

  .promo-header-links {
    justify-content: flex-start;
    gap: 4px;
  }

  .promo-header-links a {
    min-height: 32px;
    padding-inline: 8px;
    font-size: 10px;
  }

  .promo-subnav-shell {
    min-height: 40px;
    padding-inline: 12px;
  }

  .promo-shell {
    width: min(100% - 20px, 72rem);
  }

  .promo-masthead-inner {
    padding-block: 22px 22px;
  }

  .promo-breadcrumb {
    font-size: 10px;
  }

  .promo-masthead h1 {
    font-size: clamp(40px, 16vw, 64px);
    letter-spacing: -.06em;
  }

  .promo-lead {
    font-size: 13px;
    line-height: 1.48;
  }

  .promo-content {
    padding-top: 20px;
  }

  .promo-card-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .promo-card {
    min-height: 0;
    gap: 9px;
    padding: 14px;
    border-radius: 18px;
  }

  .promo-card h3 {
    font-size: 20px;
  }

  .promo-card p,
  .promo-section-intro p,
  .promo-callout p {
    font-size: 12.5px;
    line-height: 1.48;
  }

  .promo-section-intro h2,
  .promo-callout h2 {
    font-size: 25px;
    letter-spacing: -.04em;
  }

  .promo-callout {
    gap: 12px;
    margin-top: 20px;
    padding: 16px;
    border-radius: 20px;
  }

  .promo-button {
    min-height: 34px;
    padding-inline: 12px;
    font-size: 10px;
  }
}

@media (max-width: 390px) {
  .promo-header-links a {
    padding-inline: 6px;
    font-size: 9.5px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .promo-main {
    animation: none;
  }
}

.gift-detail-shell {
  position: relative;
  overflow: hidden;
  display: grid;
  gap: clamp(18px, 2.6vw, 28px);
  padding: clamp(18px, 3.6vw, 34px);
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: clamp(22px, 3vw, 34px);
  background:
    radial-gradient(circle at 12% 0%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 24rem),
    radial-gradient(circle at 86% 8%, color-mix(in srgb, var(--accent-2) 14%, transparent), transparent 26rem),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface-2) 76%, transparent));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 22px 54px rgba(0,0,0,.24);
}

.gift-detail-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,.06), transparent 40%, rgba(255,255,255,.035));
  opacity: .72;
}

.gift-detail-shell > * {
  position: relative;
  z-index: 1;
}

.gift-detail-head {
  display: grid;
  gap: clamp(8px, 1.2vw, 12px);
  max-width: 900px;
}

.gift-detail-title {
  margin: 0;
  color: var(--text);
  font-size: clamp(30px, 5vw, 68px);
  font-weight: 950;
  line-height: .95;
  letter-spacing: -.06em;
}

.gift-detail-lead {
  max-width: 780px;
  margin: 0;
  color: color-mix(in srgb, var(--text) 86%, var(--accent-2));
  font-size: clamp(15px, 1.55vw, 21px);
  font-weight: 850;
  line-height: 1.38;
  letter-spacing: -.018em;
}

.gift-promo-content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(12px, 1.6vw, 18px);
}

.gift-promo-note,
.gift-promo-block {
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 22px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface) 82%, transparent), color-mix(in srgb, var(--surface-2) 72%, transparent));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.055), 0 14px 34px rgba(0,0,0,.18);
}

.gift-promo-note {
  grid-column: 1 / -1;
  padding: clamp(12px, 1.7vw, 18px);
  color: color-mix(in srgb, var(--text) 72%, transparent);
  font-size: clamp(12.5px, .95vw, 14px);
  line-height: 1.55;
}

.gift-promo-note strong {
  color: var(--text);
  font-weight: 920;
}

.gift-promo-block {
  display: grid;
  align-content: start;
  gap: 12px;
  padding: clamp(15px, 2vw, 22px);
}

.gift-promo-block--featured,
.gift-promo-block--terms {
  grid-column: 1 / -1;
}

.gift-promo-block h3,
.gift-promo-block h4,
.gift-promo-block p,
.gift-promo-block ul {
  margin: 0;
}

.gift-promo-block h3 {
  color: var(--text);
  font-size: clamp(18px, 2vw, 27px);
  font-weight: 930;
  line-height: 1.08;
  letter-spacing: -.035em;
}

.gift-promo-block h4 {
  color: color-mix(in srgb, var(--accent-2) 76%, var(--text));
  font-size: clamp(13px, 1vw, 15px);
  font-weight: 850;
  line-height: 1.42;
  letter-spacing: -.012em;
}

.gift-promo-block ul {
  display: grid;
  gap: 8px;
  padding-left: 1.1rem;
  color: var(--muted);
  font-size: clamp(13px, .95vw, 14px);
  line-height: 1.52;
}

.gift-promo-block li::marker {
  color: color-mix(in srgb, var(--accent-2) 82%, var(--text));
}

.gift-promo-tip {
  width: fit-content;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--accent-2) 28%, transparent);
  border-radius: 16px;
  color: color-mix(in srgb, var(--text) 88%, var(--accent-2));
  background: color-mix(in srgb, var(--accent-2) 10%, transparent);
  font-size: clamp(12.5px, .92vw, 14px);
  font-weight: 850;
  line-height: 1.45;
}

.promo-callout--inline {
  margin-top: 0;
}

@media (max-width: 720px) {
  .gift-detail-shell {
    gap: 14px;
    padding: 15px;
    border-radius: 20px;
  }

  .gift-detail-title {
    font-size: clamp(26px, 10vw, 40px);
    line-height: 1;
    letter-spacing: -.045em;
  }

  .gift-detail-lead {
    font-size: 13.5px;
    line-height: 1.42;
  }

  .gift-promo-content {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .gift-promo-note,
  .gift-promo-block {
    border-radius: 17px;
  }

  .gift-promo-note {
    padding: 12px;
  }

  .gift-promo-block {
    gap: 10px;
    padding: 13px;
  }

  .gift-promo-block h3 {
    font-size: 17px;
    line-height: 1.14;
  }

  .gift-promo-block h4,
  .gift-promo-block ul,
  .gift-promo-tip {
    font-size: 12.5px;
  }

  .gift-promo-block ul {
    gap: 7px;
    padding-left: 1rem;
  }

  .promo-callout--inline {
    margin-top: 2px;
  }
}

/* === semua-kemenangan.css === */
.all-wins-page {
  min-height: 100dvh;
  padding-top: 0;
}

.all-wins-main {
  min-height: 100dvh;
  padding-block: calc(var(--header-h) + clamp(14px, 2.5vw, 28px)) clamp(34px, 5vw, 58px);
}

.all-wins-shell {
  width: min(100% - clamp(28px, 5vw, 80px), 1180px);
  margin-inline: auto;
}

.all-wins-breadcrumb {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-block-end: clamp(10px, 1.8vw, 18px);
  color: color-mix(in srgb, var(--text) 54%, transparent);
  font-size: 12px;
  font-weight: 850;
}

.all-wins-breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.all-wins-breadcrumb a:hover {
  color: var(--text);
}

.all-wins-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(160px, 220px);
  align-items: end;
  gap: clamp(14px, 2.6vw, 28px);
}

.all-wins-kicker,
.all-wins-card-kicker,
.all-wins-sort-label {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 25px;
  padding: 0 11px;
  border: 1px solid color-mix(in srgb, var(--text) 13%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  background: color-mix(in srgb, var(--surface-solid) 78%, transparent);
  font-size: 11px;
  font-weight: 950;
  line-height: 1;
  letter-spacing: .035em;
  text-transform: uppercase;
}

.all-wins-hero h1 {
  max-width: 780px;
  margin: 10px 0 0;
  color: var(--text);
  font-size: clamp(38px, 7vw, 82px);
  font-weight: 950;
  line-height: .9;
  letter-spacing: -.065em;
}

.all-wins-hero p {
  max-width: 680px;
  margin: clamp(10px, 1.4vw, 16px) 0 0;
  color: color-mix(in srgb, var(--text) 68%, transparent);
  font-size: clamp(14px, 1.35vw, 18px);
  font-weight: 650;
  line-height: 1.55;
}

.all-wins-summary {
  display: grid;
  gap: 4px;
  justify-items: start;
  padding: 18px;
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.03)),
    color-mix(in srgb, var(--surface-solid) 80%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 18px 50px rgba(0,0,0,.22);
}

.all-wins-summary span,
.all-wins-summary small {
  color: color-mix(in srgb, var(--text) 58%, transparent);
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.all-wins-summary strong {
  color: var(--text);
  font-size: clamp(42px, 6vw, 68px);
  font-weight: 950;
  line-height: .9;
}

.all-wins-channel {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
  margin-block-start: clamp(18px, 2.8vw, 32px);
  padding: clamp(14px, 2vw, 18px);
  border: 1px solid color-mix(in srgb, var(--text) 11%, transparent);
  border-radius: 24px;
  background: color-mix(in srgb, var(--surface-solid) 72%, transparent);
}

.all-wins-channel-media {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  border-radius: 20px;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  overflow: hidden;
}

.all-wins-channel-media img {
  width: 64%;
  height: 64%;
  object-fit: contain;
  filter: drop-shadow(0 14px 26px rgba(0,0,0,.32));
}

.all-wins-channel-info h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(20px, 3vw, 28px);
  line-height: 1;
  letter-spacing: -.035em;
}

.all-wins-channel-info p {
  max-width: 720px;
  margin: 8px 0 0;
  color: color-mix(in srgb, var(--text) 62%, transparent);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.45;
}

.all-wins-channel-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in srgb, var(--accent) 42%, transparent);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.all-wins-list-section {
  margin-block-start: clamp(22px, 3.6vw, 42px);
}

.all-wins-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-block-end: 14px;
}

.all-wins-toolbar p {
  margin: 0 auto 0 0;
  color: var(--text);
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 950;
  line-height: 1;
  letter-spacing: -.04em;
}

.all-wins-view-switcher {
  display: inline-flex;
  gap: 6px;
  padding: 4px;
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface-solid) 70%, transparent);
}

.all-wins-view-button {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 999px;
  color: color-mix(in srgb, var(--text) 62%, transparent);
  background: transparent;
  font-weight: 950;
}

.all-wins-view-button.is-active {
  color: var(--text);
  background: color-mix(in srgb, var(--text) 10%, transparent);
}

.all-wins-status {
  display: none;
  margin-block: 12px 18px;
  color: color-mix(in srgb, var(--text) 62%, transparent);
  font-size: 13px;
  font-weight: 800;
}

.all-wins-status:not(:empty) {
  display: block;
}

.all-wins-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 2.2vw, 24px);
  padding: 0;
  margin: 0;
  list-style: none;
}

.all-wins-card {
  min-width: 0;
}

.all-wins-card-link {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 100%;
  border: 1px solid color-mix(in srgb, var(--text) 10%, transparent);
  border-radius: 22px;
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.022)),
    color-mix(in srgb, var(--surface-solid) 80%, transparent);
  text-decoration: none;
  overflow: hidden;
  transform: translateZ(0);
  transition: border-color .16s ease, background-color .16s ease, transform .16s ease;
}

.all-wins-card-link:hover,
.all-wins-card-link:focus-visible {
  border-color: color-mix(in srgb, var(--accent-2) 48%, transparent);
  transform: translateY(-2px);
}

.all-wins-card-thumbnail {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: color-mix(in srgb, var(--surface-solid) 88%, transparent);
}

.all-wins-card-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.all-wins-card-badge {
  position: absolute;
  inset: 10px auto auto 10px;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in srgb, #000 54%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .045em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.all-wins-card-body {
  display: grid;
  gap: 10px;
  padding: 14px;
}

.all-wins-card-meta-top {
  color: color-mix(in srgb, var(--text) 52%, transparent);
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
}

.all-wins-card-title {
  margin: 0;
  color: var(--text);
  font-size: clamp(16px, 1.8vw, 21px);
  font-weight: 950;
  line-height: 1.08;
  letter-spacing: -.035em;
}

.all-wins-card-description {
  display: -webkit-box;
  min-height: 3.9em;
  margin: 0;
  color: color-mix(in srgb, var(--text) 62%, transparent);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.3;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.all-wins-card-reaction,
.all-wins-card-footer {
  display: flex;
  align-items: center;
  gap: 10px;
}

.all-wins-card-reaction {
  color: color-mix(in srgb, var(--text) 76%, transparent);
  font-size: 12px;
  font-weight: 900;
}

.all-wins-card-footer {
  margin-top: 2px;
  color: color-mix(in srgb, var(--text) 54%, transparent);
  font-size: 11px;
  font-weight: 850;
}

.all-wins-avatar {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  object-fit: cover;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
}

@media (max-width: 980px) {
  .all-wins-shell {
    width: min(100% - 28px, 720px);
  }

  .all-wins-hero-grid,
  .all-wins-channel {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .all-wins-summary {
    width: min(100%, 220px);
  }

  .all-wins-channel-media {
    width: 86px;
  }

  .all-wins-channel-link {
    width: fit-content;
  }

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

@media (max-width: 640px) {
  .all-wins-main {
    padding-block-start: calc(var(--header-h) + 12px);
  }

  .all-wins-hero h1 {
    font-size: clamp(32px, 12vw, 48px);
  }

  .all-wins-toolbar {
    align-items: flex-start;
    flex-wrap: wrap;
  }

  .all-wins-view-switcher {
    display: none;
  }

  .all-wins-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .all-wins-card-link {
    border-radius: 18px;
  }
}
