/* === fonts.css === */
:root {
  --font-system: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-heading-now: var(--font-system);
  --font-heading-now-italic: var(--font-system);
}

/* === theme.css === */
/*
  Public theme source of truth.
  Semua warna, surface, shadow, radius, dan token interaksi utama halaman publik
  dikunci di file ini agar perubahan tema tidak tersebar di modul CSS lain.
  CSS admin tetap memakai assets/css/admin.css secara terpisah.
*/
:root {
  color-scheme: dark;

  /* Typography */
  --font-main: var(--font-heading-now), var(--font-system);
  --font-display: var(--font-heading-now), var(--font-main);
  --font-display-italic: var(--font-heading-now-italic), var(--font-display);
  --font-axis-width-body: 648;
  --font-axis-width-ui: 670;
  --font-axis-width-display: 725;
  --font-axis-width-action: 760;
  --font-axis-width-condensed: 620;
  --font-axis-weight-body: 400;
  --font-axis-weight-ui: 550;
  --font-axis-weight-strong: 650;
  --font-axis-weight-action: 650;
  --font-axis-weight-display: 750;
  --font-axis-weight-heavy: 830;

  --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;
  --ui-transition-fast: .16s ease;
  --ui-transition-base: .24s ease;

  /* App background */
  --bg: #101014;
  --bg-soft: #15161d;
  --surface: rgba(16, 16, 20, .82);
  --surface-2: rgba(24, 24, 29, .78);
  --surface-3: rgba(42, 42, 48, .86);
  --surface-solid: #15161d;

  /* Text */
  --text: #f8f8fa;
  --muted: rgba(248, 248, 250, .72);
  --subtle: rgba(248, 248, 250, .54);

  /* Lines */
  --line: rgba(255, 255, 255, .10);
  --line-strong: rgba(255, 255, 255, .18);

  /* Neutral action colors: dark/glass first, no colored cool accent in default theme. */
  --accent: #e6e6e8;
  --accent-2: #f4f4f5;
  --accent-contrast: #101014;
  --danger: #fb7185;
  --good: #34d399;
  --warn: #fbbf24;

  /* 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(48,48,52,.70);
  --surface-menu-border: rgba(255,255,255,.10);

  /* Public game-card visual contract */
  --game-card-bg: rgba(48,48,52,.60);
  --game-card-bg-hover: rgba(58,58,64,.66);
  --game-card-bg-active: rgba(58,58,64,.66);
  --game-card-border: rgba(255,255,255,.10);
  --game-card-border-hover: rgba(255,255,255,.16);
  --game-card-outline: rgba(255,255,255,.35);
  --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(13,18,28,.32), rgba(13,18,28,.72));
  --game-title-glass-border: rgba(255,255,255,.14);
  --game-title-glass-shadow: 0 8px 18px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.10);
  --game-progress-height: 18px;
  --game-progress-height-mobile: 17px;
  --game-progress-value-inset: 6px;
  --game-card-shadow: rgba(0,0,0,.20) 0 5px 5px -3px, rgba(0,0,0,.14) 0 8px 10px 1px, rgba(0,0,0,.12) 0 3px 14px 2px;
  --game-card-shadow-hover: rgba(0,0,0,.22) 0 7px 7px -3px, rgba(0,0,0,.16) 0 10px 14px 1px, rgba(0,0,0,.14) 0 4px 18px 2px;
  --game-card-shadow-mobile: 0 5px 12px rgba(0,0,0,.16);
  --game-card-backdrop: blur(18px) saturate(145%);
  --game-card-mobile-backdrop: none;

  /* Pattern preview glass, aligned with the header reference: dark transparent surface, soft blur, white hover-grade line. */
  --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), 0 8px 18px rgba(0,0,0,.12);
  --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;

  /* Header glass color contract, adapted from the supplied desktop/mobile reference while preserving the existing header DOM and JS. */
  --header-glass-bg: rgba(16,16,20,.70);
  --header-glass-bg-elevated: rgba(16,16,20,.82);
  --header-glass-border: rgba(255,255,255,.10);
  --header-glass-border-strong: rgba(255,255,255,.15);
  --header-glass-blur: blur(24px) saturate(155%);
  --header-mobile-glass-bg: rgba(16,16,20,.88);
  --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,.18);
  --header-control-text: rgba(255,255,255,.82);
  --header-control-text-hover: #fff;
  --header-focus-ring: 0 0 0 2px rgba(255,255,255,.12);
  --header-register-bg: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.07));
  --header-register-bg-hover: linear-gradient(180deg, rgba(255,255,255,.21), rgba(255,255,255,.09));
  --header-register-border: rgba(255,255,255,.18);
  --header-register-border-hover: rgba(255,255,255,.24);
  --header-register-text: #fff;
  --header-register-text-hover: #fff;
  --header-register-shadow: inset 0 1px 0 rgba(255,255,255,.13);
  --header-register-shadow-hover: inset 0 1px 0 rgba(255,255,255,.16);

  /* Buttons and rail hover state */
  --interactive-soft-bg: rgba(255,255,255,.055);
  --interactive-soft-bg-hover: rgba(255,255,255,.085);
  --interactive-soft-border: rgba(255,255,255,.10);
  --interactive-soft-border-hover: rgba(255,255,255,.16);
  --carousel-control-size: 30px;
  --carousel-control-radius: 7px;
  --carousel-control-bg: rgba(255,255,255,.36);
  --carousel-control-bg-hover: rgba(255,255,255,.48);
  --carousel-control-color: #fff;
  --carousel-control-shadow: 0 6px 16px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.16);
  --carousel-outline-idle: .625rem;
  --carousel-outline-active: .1875rem;
  --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 26px 70px rgba(0, 0, 0, .34);
  --shadow-soft: 0 16px 42px rgba(0, 0, 0, .20);
  --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(125, 211, 252, .18);

  /* Toast / short-message system, adapted from the pasted Sonner-style reference. */
  --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);
  font-variation-settings: "wdth" var(--font-axis-width-body), "wght" var(--font-axis-weight-body);
  line-height: var(--text-line-body);
  letter-spacing: var(--text-letter-ui);
  overflow-wrap: anywhere;
}

h1,
h2,
h3,
.section-title,
.hero-title,
.hero-copy h1,
.jackpot-page-title,
.promo-hero-title,
.all-wins-title {
  font-family: var(--font-display);
  font-weight: var(--text-weight-display);
  font-variation-settings: "wdth" var(--font-axis-width-display), "wght" var(--font-axis-weight-display);
  line-height: var(--text-line-tight);
  letter-spacing: -.035em;
  text-wrap: balance;
}

p,
.section-kicker,
.section-subtitle,
.hero-description,
.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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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;
  font-variation-settings: "wdth" var(--font-axis-width-action), "wght" var(--font-axis-weight-action);
}

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,
  .hero-title,
  .hero-copy h1,
  .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 {
  min-width: 0;
  min-height: 100%;
  margin: 0;
  color: var(--text);
  background:
    radial-gradient(circle at 12% -10%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 32rem),
    radial-gradient(circle at 92% 2%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 34rem),
    linear-gradient(180deg, var(--bg-soft), var(--bg) 28rem),
    var(--bg);
  font-family: var(--font-main);
  font-size: var(--text-size-body);
  font-weight: var(--text-weight-body);
  font-variation-settings: "wdth" var(--font-axis-width-body), "wght" var(--font-axis-weight-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  overscroll-behavior-x: 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 === */
.site-header,
.global-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 80;
  height: var(--header-h);
  border-bottom: 1px solid var(--line);
  background: color-mix(in srgb, var(--bg) 94%, transparent);
  backdrop-filter: saturate(135%) blur(10px);
  -webkit-backdrop-filter: saturate(135%) blur(10px);
  }

.global-header.is-elevated {
  border-bottom-color: var(--line);
  box-shadow: none;
}

body {
  padding-top: var(--header-h);
}

.global-header-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 46%, color-mix(in srgb, var(--accent-2) 6%, transparent));
  opacity: .52;
}

.global-header-nav {
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  width: min(1440px, calc(100% - 24px));
  height: 100%;
  margin-inline: auto;
}

.brand,
.property-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
  min-width: 0;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  border-radius: 15px;
  color: var(--accent-contrast);
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  font-weight: 950;
  letter-spacing: -.04em;
  box-shadow: 0 3px 9px color-mix(in srgb, var(--accent) 8%, transparent);
}

.brand-copy {
  display: grid;
  gap: 3px;
  line-height: 1;
}

.brand-copy strong {
  font-size: 15px;
  letter-spacing: .01em;
}

.brand-copy small {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.global-header-drawer {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1;
  min-width: 0;
}

.top-nav,
.main-nav-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  flex: 1;
  padding: 0;
  margin: 0;
  list-style: none;
}

.header-tools {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 0 1 auto;
  min-width: 0;
}

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

.section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 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;
  gap: 10px;
}

.section-title-link h2,
.section-head h2,
.catalog-head h2 {
  margin: 0;
  font-size: clamp(26px, 3vw, 42px);
  line-height: .98;
  letter-spacing: -.045em;
  text-wrap: balance;
}

.section-title-arrow {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  color: var(--accent);
}

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

/* === components.css === */
.top-nav a,
.header-tool,
.sign-in-link,
.button,
.link-button,
.category-chip,
.detail-button,
.icon-button,
.sort-menu__button {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--glass-bg);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .08) inset;
  transition: transform .16s ease, border-color .16s ease, background-color .16s ease, color .16s ease, box-shadow .16s ease;
}

.top-nav a,
.header-tool,
.sign-in-link,
.button,
.link-button,
.category-chip,
.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;
}

.top-nav a:hover,
.top-nav a:focus-visible,
.top-nav a[aria-current="page"],
.top-nav a.is-active,
.header-tool:hover,
.sign-in-link:hover,
.button:hover,
.link-button:hover,
.category-chip:hover,
.sort-menu__button:hover {
  color: var(--text);
  border-color: var(--line-strong);
  background: var(--glass-bg-strong);
}

.button.primary,
.category-chip.is-active,
.sort-menu__option.is-active {
  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: 0 1px 0 rgba(255,255,255,.14) inset, 0 3px 9px color-mix(in srgb, var(--accent) 8%, transparent);
}

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

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

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

.menu-toggle {
  display: none;
  place-items: center;
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--glass-bg);
}

.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: transform .18s ease, top .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);
}

.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 var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--glass-bg);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .08) inset;
  backdrop-filter: blur(14px) saturate(136%);
  -webkit-backdrop-filter: blur(14px) saturate(136%);
  overflow: hidden;
  isolation: isolate;
  transform: translateZ(0);
  transition: border-color .16s ease, background .16s ease, box-shadow .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: var(--line-strong);
  background: var(--glass-bg-strong);
  box-shadow: 0 1px 0 rgba(255, 255, 255, .10) inset, var(--focus-ring);
}

.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 var(--line-strong);
  border-radius: 18px;
  background: linear-gradient(180deg, color-mix(in srgb, var(--surface-solid) 88%, transparent), color-mix(in srgb, var(--surface) 82%, transparent));
  box-shadow: 0 18px 44px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(18px) saturate(155%);
  -webkit-backdrop-filter: blur(18px) saturate(155%);
  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;
  width: var(--carousel-control-size, 30px);
  height: var(--carousel-control-size, 30px);
  margin: 0;
  padding: 0;
  border: 0;
  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: var(--carousel-control-shadow, 0 6px 16px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.16));
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle, 0);
  outline-style: solid;
  outline-width: 0;
  opacity: .92;
  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: 16px;
  height: 16px;
}

.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 {
  flex: 0 0 auto;
  white-space: nowrap;
}

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

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

.sort-menu__button > svg {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  fill: currentColor;
  opacity: .82;
}

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

.provider-chip {
  min-width: max-content;
}

.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 var(--surface-menu-border);
  color: #fff;
  background-color: var(--surface-menu-bg);
  background-image: none;
  box-shadow:
    var(--game-card-shadow);
  backdrop-filter: blur(50px);
  -webkit-backdrop-filter: blur(50px);
  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, .54);
  opacity: 0;
  pointer-events: none;
  contain: layout paint style;
  transition: opacity .18s ease;
}

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

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

.rtpx-loading-overlay__spinner {
  width: 42px;
  height: 42px;
  display: block;
  border-radius: 999px;
  border: 3px solid rgba(255, 255, 255, .28);
  border-top-color: #fff;
  border-right-color: #fff;
  background: transparent;
  animation: rtpx-loading-spin .72s 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 === */
.hero:not(.hero-showcase) {
  position: relative;
  min-height: clamp(500px, 70vh, 700px);
  display: grid;
  align-items: end;
  isolation: isolate;
  overflow: hidden;
}

.hero-media,
.hero-media img,
.hero-overlay {
  position: absolute;
  inset: 0;
}

.hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.04) contrast(1.02);
  transition: opacity .18s ease, transform .4s ease;
}

.hero-media img.is-changing {
  opacity: .2;
  transform: scale(1.012);
}

.hero-overlay {
  z-index: 1;
  background:
    radial-gradient(circle at 50% 58%, rgba(9, 12, 18, .06), rgba(9, 12, 18, .52) 48%, rgba(9, 12, 18, .82) 100%),
    linear-gradient(180deg, rgba(5, 8, 13, .10) 0%, rgba(5, 8, 13, .28) 46%, var(--bg) 100%);
}

.hero-content {
  position: relative;
  z-index: 2;
  display: grid;
  justify-items: center;
  width: var(--shell);
  padding: 112px 0 clamp(72px, 7vw, 96px);
  text-align: center;
}

.hero-panel {
  display: grid;
  justify-items: center;
  gap: 10px;
  width: min(620px, 100%);
  max-width: 620px;
  margin-inline: auto;
}

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

.hero:not(.hero-showcase) h1 {
  max-width: 640px;
  margin: 0;
  font-size: clamp(34px, 5.6vw, 68px);
  line-height: .93;
  letter-spacing: -.055em;
  text-wrap: balance;
}

.hero:not(.hero-showcase) p {
  max-width: 420px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(12.5px, 1.15vw, 15px);
  font-weight: 650;
  line-height: 1.45;
  text-wrap: balance;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
}

.discovery-sections,
.featured,
.news-section,
.catalog {
  padding-block: clamp(12px, 1.55vw, 22px);
  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(10px, 1.2vw, 18px);
  overflow: visible;
  isolation: isolate;
}

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

.content-row-head {
  margin-bottom: 4px;
}

.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: 10px var(--featured-edge-fade, 18px) 14px 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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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: 10px 18px 14px 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-medium, var(--accent)) 24%, rgba(255,255,255,.08));
  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, #202024) 88%, #09090C), color-mix(in srgb, var(--rtpx-progress-track, #202024) 72%, var(--rtpx-progress-medium, var(--accent))));
  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,
      color-mix(in srgb, var(--rtpx-progress-stable, var(--accent-2)) 76%, var(--rtpx-progress-medium, var(--accent))),
      var(--rtpx-progress-medium, var(--accent)) 58%,
      color-mix(in srgb, var(--rtpx-progress-high, #f4f4f5) 82%, var(--rtpx-progress-medium, var(--accent))) 100%);
  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, var(--accent)) 30%, 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);
  font-variation-settings: "wdth" var(--font-axis-width-action), "wght" var(--font-axis-weight-action);
  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="high"] .game-progress-fill {
  background:
    linear-gradient(90deg,
      color-mix(in srgb, var(--rtpx-progress-medium, var(--accent)) 78%, #18181d),
      var(--rtpx-progress-medium, var(--accent)) 48%,
      var(--rtpx-progress-high, #f4f4f5) 100%);
}

.game-progress[data-progress-tier="medium"] .game-progress-fill {
  background:
    linear-gradient(90deg,
      color-mix(in srgb, var(--rtpx-progress-stable, #d7d7dc) 55%, var(--rtpx-progress-medium, var(--accent))),
      var(--rtpx-progress-medium, var(--accent)) 100%);
}

.game-progress[data-progress-tier="stable"] .game-progress-fill {
  background:
    linear-gradient(90deg,
      color-mix(in srgb, var(--rtpx-progress-stable, var(--accent-2)) 86%, var(--rtpx-progress-track, #202024)),
      color-mix(in srgb, var(--rtpx-progress-medium, var(--accent)) 82%, var(--rtpx-progress-stable, var(--accent-2))) 100%);
}

.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);
  font-variation-settings: "wdth" var(--font-axis-width-action), "wght" var(--font-axis-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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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);
  font-variation-settings: "wdth" var(--font-axis-width-action), "wght" var(--font-axis-weight-action);
  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;
}

.hero-actions {
  align-items: center;
}

.hero-actions .button {
  min-width: 148px;
  min-height: 42px;
  padding-inline: 18px;
  border-radius: 18px;
}

.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);
  font-variation-settings: "wdth" var(--font-axis-width-ui), "wght" var(--font-axis-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;
}

/* === 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);
  border-radius: var(--carousel-control-radius);
  opacity: .92;
}

.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: none;
  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.25rem;
  }

    .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;
  width: var(--carousel-control-size);
  height: var(--carousel-control-size);
  padding: 0;
  border: 0;
  border-radius: var(--carousel-control-radius);
  color: var(--carousel-control-color);
  background: var(--carousel-control-bg);
  box-shadow: var(--carousel-control-shadow);
  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: var(--carousel-control-bg-hover);
  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: none;
  transform: translate3d(0, -50%, 0) scale(.96);
}

.content-rail-button .carousel-next-icon,
.content-rail-button .carousel-control-icon {
  width: 16px;
  height: 16px;
}

.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.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 {
    --header-h: 66px;
    --shell: min(100% - 24px, 1440px);
  }

  .menu-toggle {
    display: grid;
    margin-left: auto;
  }

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

  .global-header__drawer {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    right: 0;
    display: grid;
    align-items: stretch;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line-strong);
    border-radius: 22px;
    background: color-mix(in srgb, var(--surface-solid) 90%, transparent);
    box-shadow: 0 18px 48px rgba(0,0,0,.30);
    backdrop-filter: blur(16px) saturate(145%);
    -webkit-backdrop-filter: blur(16px) saturate(145%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-8px) scale(.985);
    transition: opacity .16s ease, visibility .16s ease, transform .16s ease;
  }

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

  .top-nav,
  .main-nav__list,
  .tools {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    width: 100%;
  }

  .top-nav a,
  .header-tool,
  .tools .search {
    width: 100%;
  }

  .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 {
    --header-h: 64px;
    --shell: min(100% - 22px, 1440px);
  }

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

  .hero:not(.hero-showcase) {
    min-height: clamp(456px, 68dvh, 600px);
  }

  .hero-media img {
    object-position: 62% center;
  }

  .hero-overlay {
    background:
      linear-gradient(90deg, rgba(5, 8, 13, .92) 0%, rgba(5, 8, 13, .64) 48%, rgba(5, 8, 13, .24) 100%),
      linear-gradient(180deg, rgba(5, 8, 13, .18), var(--bg) 100%);
  }

  .hero-content {
    padding-block: 54px 32px;
  }

  .hero-panel {
    max-width: 96%;
    gap: 13px;
  }

  .hero:not(.hero-showcase) h1 {
    max-width: 96%;
    font-size: clamp(34px, 10.6vw, 54px);
    line-height: .94;
    letter-spacing: -.055em;
  }

  .hero:not(.hero-showcase) p {
    max-width: 94%;
    font-size: 15px;
    line-height: 1.55;
  }

  .hero-actions {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    gap: 8px;
    max-width: 96%;
  }

  .hero-actions .button {
    flex: 0 1 auto;
    min-width: 0;
    min-height: 40px;
    padding-inline: 14px;
    border-radius: 15px;
    font-size: 13px;
  }

  .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 {
    --header-h: 60px;
    --shell: min(100% - 18px, 1440px);
  }

  .site-header,
  .global-header {
    background: var(--bg);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .global-header-bg {
    opacity: .34;
  }

  .global-header__nav {
    width: min(100% - 18px, 1440px);
    gap: 10px;
  }

  .brand-copy {
    display: none;
  }

  .brand-mark {
    width: 38px;
    height: 38px;
    border-radius: 14px;
  }

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

  .global-header__drawer {
    top: calc(100% + 7px);
    padding: 10px;
    border-radius: 18px;
  }

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

  .section-title-link h2,
  .section-head h2,
  .catalog-head h2 {
    font-size: 26px;
    line-height: 1;
  }

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

  .hero:not(.hero-showcase) {
    min-height: clamp(420px, 64dvh, 520px);
  }

  .hero-media img {
    object-position: 67% center;
  }

  .hero-content {
    padding-top: 38px;
    padding-bottom: 24px;
  }

  .hero-panel {
    max-width: 100%;
    gap: 11px;
  }

  .hero:not(.hero-showcase) h1 {
    max-width: 98%;
    font-size: clamp(30px, 9.8vw, 42px);
    line-height: .97;
    letter-spacing: -.048em;
  }

  .hero:not(.hero-showcase) p {
    max-width: 98%;
    font-size: 14px;
    line-height: 1.5;
  }

  .hero-actions {
    max-width: 100%;
    gap: 7px;
  }

  .hero-actions .button {
    min-height: 36px;
    padding-inline: 11px;
    border-radius: 13px;
    font-size: 12.5px;
  }

  .toolbar {
    grid-template-columns: minmax(0, 1fr) minmax(104px, 122px);
    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 {
    width: 14px;
    height: 14px;
  }

  .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, 30px);
    height: var(--carousel-control-size, 30px);
    --control-inline: 4px;
  }

  .carousel-next-icon,
  .carousel-control-icon {
    width: 16px;
    height: 16px;
  }

  .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 {
    --header-h: 58px;
    --shell: min(100% - 16px, 1440px);
  }

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

  .brand-mark {
    width: 36px;
    height: 36px;
    border-radius: 13px;
    font-size: 14px;
  }

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

  .hero:not(.hero-showcase) {
    min-height: clamp(398px, 62dvh, 500px);
  }

  .hero-content {
    padding-top: 32px;
    padding-bottom: 22px;
  }

  .hero:not(.hero-showcase) h1 {
    font-size: clamp(28px, 9.2vw, 38px);
    letter-spacing: -.043em;
  }

  .hero:not(.hero-showcase) p {
    font-size: 13px;
  }

  .hero-actions .button {
    min-height: 34px;
    padding-inline: 10px;
    font-size: 11.8px;
  }

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

  .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: 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) 92px;
    gap: 6px;
  }

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

  .sort-menu__button > svg {
    width: 13px;
    height: 13px;
  }

  .hero-actions {
    gap: 6px;
  }

  .hero-actions .button {
    padding-inline: 8px;
    font-size: 11.2px;
  }

  .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) 86px;
  }

  .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: 2.35rem;
    height: 2.35rem;
  }

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

@media (max-width: 760px) {
  .hero:not(.hero-showcase) {
    min-height: clamp(390px, 62dvh, 520px);
  }

  .hero-overlay {
    background:
      radial-gradient(circle at 50% 56%, rgba(9, 12, 18, .10), rgba(9, 12, 18, .58) 52%, rgba(9, 12, 18, .86) 100%),
      linear-gradient(180deg, rgba(5, 8, 13, .10) 0%, rgba(5, 8, 13, .30) 44%, var(--bg) 100%);
  }

  .hero-content {
    display: grid;
    justify-items: center;
    padding-block: 42px 66px;
    text-align: center;
  }

  .hero-panel {
    justify-items: center;
    width: min(100%, 420px);
    max-width: 420px;
    gap: 8px;
  }

  .hero:not(.hero-showcase) h1 {
    max-width: 360px;
    font-size: clamp(25px, 7.6vw, 36px);
    line-height: .96;
    letter-spacing: -.045em;
  }

  .hero:not(.hero-showcase) p {
    max-width: 300px;
    font-size: 12.5px;
    line-height: 1.35;
  }

  .hero-actions {
    justify-content: center;
    gap: 7px;
    max-width: 100%;
    margin-top: 2px;
  }

  .hero-actions .button {
    min-height: 34px;
    padding-inline: 11px;
    border-radius: 999px;
    font-size: 11.8px;
  }
}

@media (max-width: 420px) {
  .hero:not(.hero-showcase) {
    min-height: clamp(360px, 58dvh, 470px);
  }

  .hero-content {
    padding-block: 34px 58px;
  }

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

  .hero:not(.hero-showcase) h1 {
    max-width: 310px;
    font-size: clamp(22px, 7vw, 30px);
  }

  .hero:not(.hero-showcase) p {
    max-width: 270px;
    font-size: 11.5px;
  }

  .hero-actions .button {
    min-height: 27px;
    padding-inline: 10px;
    font-size: 11px;
  }
}

/* === hero.css === */
/*
  Hero banner module rebuilt from the supplied no8po reference.
  Existing project classes are preserved; no8po class aliases are supported for future HTML reuse.
*/

.catalog-page {
  position: relative;
  overflow: hidden;
  overflow-anchor: none;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.045), transparent 34rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 84%, var(--bg)) 0, var(--bg) 35rem, var(--bg) 100%);
}

.hero,
.hero-showcase,
.no8po07 {
  position: relative;
  isolation: isolate;
}

.hero-showcase {
  --hero-ratio-w: 16;
  --hero-ratio-h: 9;
  --hero-base-ratio: 16 / 9;
  --hero-wide-ratio: 21 / 9;
  --hero-active-ratio: var(--hero-base-ratio);
  --hero-max-width: 120rem;
  --hero-dark: #101014;
  --hero-overlay-dark: rgba(16,16,20,.94);
  --hero-reflection-image: none;
  --hero-reflection-opacity: .24;
  --hero-pagination-offset: clamp(34px, 3.4vw, 46px);
  --hero-mobile-media-height: 56.25vw;
  --hero-frame-width: min(var(--hero-max-width), calc(100vw - 32px));
  --hero-safe-edge: max(1.5rem, calc((100vw - var(--hero-max-width)) / 2));
  --hero-content-pad: clamp(1.5rem, 4vw, 4rem);
  --hero-copy-shift: clamp(1.25rem, 4vw, 5rem);
  --hero-copy-width: min(30rem, calc(50% - clamp(5.75rem, 8vw, 8rem)));
  --hero-copy-max: 30rem;
  --hero-art-right-16: max(1.5rem, calc((100vw - var(--hero-max-width)) / 2 + clamp(2rem, 4vw, 4rem)));
  --hero-art-right-21: max(0rem, calc((100vw - var(--hero-max-width)) / 2 + clamp(.5rem, 2vw, 2rem)));
  width: 100%;
  max-width: none;
  min-height: clamp(32rem, 43vw, 40rem);
  margin: 0 auto var(--hero-pagination-offset);
  overflow: visible;
  overflow-anchor: none;
  color: var(--text);
  background: var(--hero-dark);
}

.hero-showcase[data-active-ratio="16-9"],
.hero-showcase[data-active-ratio="auto"] {
  --hero-ratio-w: 16;
  --hero-ratio-h: 9;
  --hero-active-ratio: var(--hero-base-ratio);
}

.hero-showcase[data-active-ratio="21-9"] {
  --hero-ratio-w: 21;
  --hero-ratio-h: 9;
  --hero-active-ratio: var(--hero-wide-ratio);
  --hero-mobile-media-height: 42.857vw;
}

.hero-showcase:empty,
.hero-swiper-wrapper:empty {
  background: var(--hero-dark);
}

.hero-swiper,
.hero-swiper-wrapper,
.hero-showcase-frame,
.hero-showcase-layout,
.hero-showcase-art,
.hero-showcase-backdrop,
.hero-showcase-backdrop::after,
.hero-showcase-image-shell {
  position: absolute;
  inset: 0;
}

.hero-swiper {
  z-index: 1;
  overflow: visible;
}

.hero-swiper-wrapper {
  overflow: visible;
}

.hero-slide {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s ease-out;
  will-change: opacity;
}

.hero-slide.is-active {
  z-index: 1;
  opacity: 1;
  pointer-events: auto;
}

.hero-showcase-frame,
.hero-showcase-layout {
  width: 100%;
  overflow: hidden;
}

.hero-showcase-frame::before,
.hero-showcase-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  pointer-events: none;
}

.hero-showcase-frame::before {
  z-index: 2;
  background:
    linear-gradient(90deg,
      var(--hero-dark) 0%,
      rgba(16,16,20,.94) 4%,
      rgba(16,16,20,.62) 13%,
      rgba(16,16,20,.18) 27%,
      rgba(16,16,20,0) 42%,
      rgba(16,16,20,0) 61%,
      rgba(16,16,20,.24) 78%,
      rgba(16,16,20,.72) 92%,
      var(--hero-dark) 100%),
    linear-gradient(180deg,
      rgba(16,16,20,.48) 0%,
      rgba(16,16,20,.08) 16%,
      rgba(16,16,20,0) 44%,
      rgba(16,16,20,.18) 68%,
      rgba(16,16,20,.64) 88%,
      var(--bg) 100%);
}

.hero-showcase-frame::after {
  z-index: 1;
  inset: -7% -12% -10%;
  background:
    radial-gradient(ellipse at 0% 42%, rgba(255,255,255,.055), transparent 48%),
    radial-gradient(ellipse at 100% 42%, rgba(255,255,255,.052), transparent 48%),
    radial-gradient(ellipse at 50% 100%, rgba(255,255,255,.040), transparent 58%);
  filter: blur(34px);
  opacity: .58;
}

.hero-showcase-layout,
.hero-showcase-layout.no8po07 {
  position: relative;
  z-index: 4;
  width: 100%;
  max-width: none;
  margin-inline: auto;
}

.no8po07:not(.hero-showcase):not(.hero-showcase-layout) {
  max-width: var(--hero-max-width);
}

.hero-showcase-art {
  z-index: 0;
  pointer-events: none;
  background: var(--hero-dark);
}

.hero-showcase-backdrop,
.no8po0r {
  inset: 0;
  pointer-events: none;
  position: absolute;
}

.hero-showcase-backdrop::before {
  content: "";
  position: absolute;
  inset: -12% -10% -18%;
  z-index: 0;
  display: block;
  pointer-events: none;
  background-image: var(--hero-reflection-image);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  filter: blur(2.65rem) saturate(1.22) brightness(.76) contrast(1.04);
  opacity: var(--hero-reflection-opacity);
  transform: scale(1.06);
  -webkit-mask-image: radial-gradient(ellipse at 60% 42%, black 0%, rgba(0,0,0,.72) 38%, transparent 74%);
  mask-image: radial-gradient(ellipse at 60% 42%, black 0%, rgba(0,0,0,.72) 38%, transparent 74%);
}

.hero-showcase-backdrop {
  inset-block: 0;
  inset-inline: auto;
  left: 50%;
  z-index: 0;
  width: 100vw;
  overflow: hidden;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 74% 32%, rgba(255,255,255,.08), transparent 28rem),
    radial-gradient(circle at 18% 64%, rgba(255,255,255,.035), transparent 24rem),
    linear-gradient(180deg, rgba(16,16,20,.10), rgba(16,16,20,.88));
}

.hero-showcase-backdrop-image {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transform: scale(1.16);
  filter: blur(2.25rem) saturate(1.16) brightness(.62) contrast(1.05);
  opacity: .86;
  user-select: none;
}

.hero-showcase-backdrop::after {
  content: "";
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg,
      rgba(16,16,20,.96) 0%,
      rgba(16,16,20,.80) 16%,
      rgba(16,16,20,.32) 38%,
      rgba(16,16,20,.08) 62%,
      rgba(16,16,20,.44) 100%),
    linear-gradient(180deg,
      rgba(16,16,20,.04) 0%,
      rgba(16,16,20,.10) 58%,
      rgba(16,16,20,.62) 88%,
      var(--bg) 100%);
}

.hero-showcase-image-shell {
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.hero-showcase-image-shell::before,
.hero-showcase-image-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  display: block;
  pointer-events: none;
}

.hero-showcase-image-shell::before {
  background:
    linear-gradient(180deg,
      var(--hero-dark) 0%,
      rgba(16,16,20,.76) 1.5%,
      rgba(16,16,20,.22) 9%,
      rgba(16,16,20,0) 22%,
      rgba(16,16,20,0) 55%,
      rgba(16,16,20,.16) 68%,
      rgba(16,16,20,.48) 82%,
      rgba(16,16,20,.78) 92%,
      var(--bg) 100%);
}

.hero-showcase-image-shell::after {
  background:
    linear-gradient(90deg,
      var(--hero-dark) 0%,
      rgba(16,16,20,.88) 5%,
      rgba(16,16,20,.46) 16%,
      rgba(16,16,20,.10) 32%,
      rgba(16,16,20,0) 48%,
      rgba(16,16,20,0) 60%,
      rgba(16,16,20,.18) 78%,
      rgba(16,16,20,.64) 92%,
      var(--hero-dark) 100%);
  opacity: .86;
}

.hero-showcase-image-mask,
.no8po0k {
  position: absolute;
  inset-block: 0;
  height: 100%;
  max-width: 1400px;
  z-index: 0;
  overflow: hidden;
  transform: translateZ(0);
  transform-origin: top right;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 16%, black 82%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, black 16%, black 82%, transparent 100%);
}

.hero-showcase-image-mask::before {
  content: "";
  position: absolute;
  inset: -8%;
  z-index: 0;
  display: block;
  pointer-events: none;
  background-image: var(--hero-reflection-image);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  filter: blur(1.35rem) saturate(1.18) brightness(.92);
  opacity: .20;
  transform: scale(1.04);
}

.hero-slide[data-hero-ratio-mode="21-9"] .hero-showcase-image-mask,
.no8po0n {
  aspect-ratio: 21 / 9;
  inset-inline-start: auto;
  inset-inline-end: var(--hero-art-right-21);
}

.hero-slide:not([data-hero-ratio-mode="21-9"]) .hero-showcase-image-mask,
.hero-slide[data-hero-ratio-mode="16-9"] .hero-showcase-image-mask,
.hero-slide[data-hero-ratio-mode="auto"] .hero-showcase-image-mask,
.no8po0m {
  aspect-ratio: 16 / 9;
  inset-inline-start: auto;
  inset-inline-end: var(--hero-art-right-16);
}

.hero-slide[data-hero-image-only="true"] .hero-showcase-image-mask {
  width: min(100%, 1480px);
  max-width: 1480px;
  aspect-ratio: var(--hero-active-ratio);
  inset-inline-start: 50%;
  inset-inline-end: auto;
  transform: translateX(-50%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 15%, black 85%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, black 15%, black 85%, transparent 100%);
}

.hero-showcase-image,
.no8po010 {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  filter: saturate(1.02) contrast(1.02) brightness(.98);
  transform: translateZ(0);
  user-select: none;
}

.hero-showcase-placeholder {
  display: block;
  width: min(100%, 1480px);
  height: 100%;
  border-radius: 0;
  background:
    radial-gradient(circle at 72% 30%, rgba(255,255,255,.12), transparent 26rem),
    linear-gradient(135deg, color-mix(in srgb, var(--bg-soft) 82%, #101014), #101014 70%);
}

.hero-showcase-art::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(90deg,
      rgba(16,16,20,.94) 0%,
      rgba(16,16,20,.76) 17%,
      rgba(16,16,20,.34) 39%,
      rgba(16,16,20,.07) 60%,
      rgba(16,16,20,.20) 82%,
      rgba(16,16,20,.58) 100%),
    linear-gradient(180deg,
      rgba(16,16,20,.02) 0%,
      rgba(16,16,20,.00) 38%,
      rgba(16,16,20,.14) 62%,
      rgba(16,16,20,.42) 78%,
      rgba(16,16,20,.72) 90%,
      var(--bg) 100%);
}

.hero-slide[data-hero-image-only="true"] .hero-showcase-art::after {
  background:
    linear-gradient(90deg,
      rgba(16,16,20,.50) 0%,
      rgba(16,16,20,.12) 18%,
      rgba(16,16,20,.00) 50%,
      rgba(16,16,20,.12) 82%,
      rgba(16,16,20,.50) 100%),
    linear-gradient(180deg,
      rgba(16,16,20,.00) 0%,
      rgba(16,16,20,.00) 46%,
      rgba(16,16,20,.18) 66%,
      rgba(16,16,20,.52) 86%,
      var(--bg) 100%);
}

.hero-showcase-beam,
.hero-showcase-spark {
  position: absolute;
  z-index: 3;
  display: block;
  border: 0;
  pointer-events: none;
}

.hero-showcase-beam {
  left: 50%;
  bottom: -72px;
  width: min(64vw, 760px);
  height: clamp(92px, 12vw, 176px);
  border-radius: 999px;
  background: radial-gradient(ellipse at 50% 50%, rgba(255,255,255,.07), rgba(255,255,255,.035) 36%, transparent 72%);
  filter: blur(2.25rem);
  opacity: .26;
  transform: translateX(-50%) scale(2.1);
}

.hero-showcase-spark {
  right: 12%;
  bottom: 24%;
  width: min(13vw, 150px);
  height: min(7vw, 70px);
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,.10), rgba(255,255,255,.04) 38%, transparent 72%);
  filter: blur(1.5rem);
  opacity: .20;
  transform: scale(2.6);
}

.hero-showcase-copy-area {
  position: absolute;
  inset: 0;
  z-index: 12;
  display: grid;
  align-items: center;
  justify-items: stretch;
  width: 100%;
  height: 100%;
  min-height: 100%;
  padding: 0;
  text-align: center;
  pointer-events: none;
}

.hero-showcase-copy-shell {
  position: relative;
  z-index: 1;
  display: grid;
  align-items: center;
  justify-items: start;
  width: var(--hero-frame-width);
  height: 100%;
  margin-inline: auto;
  padding-inline-start: calc(var(--hero-content-pad) + var(--hero-copy-shift));
  padding-inline-end: var(--hero-content-pad);
  box-sizing: border-box;
}

.hero-showcase-copy,
.hero-showcase-copy-stack,
.hero-showcase-logo-motion,
.hero-showcase-action-motion,
.hero-showcase-logo-block {
  position: relative;
  z-index: 2;
  display: grid;
}

.hero-showcase-copy,
.no8po0h {
  width: var(--hero-copy-width);
  max-width: var(--hero-copy-max);
  pointer-events: auto;
}

.hero-showcase-copy-stack {
  width: 100%;
  gap: 12px;
  justify-items: center;
  text-align: center;
  opacity: 1;
  transform: translate3d(0, 0, 0);
  will-change: transform, opacity;
}

.hero-slide.is-entering .hero-showcase-copy-stack {
  animation: hero-copy-enter .56s cubic-bezier(.22, .78, .22, 1) both;
}

.hero-slide.is-exiting .hero-showcase-copy-stack {
  animation: hero-copy-exit .36s cubic-bezier(.42, 0, .2, 1) both;
}

@keyframes hero-copy-enter {
  from {
    opacity: 0;
    transform: translate3d(34px, 0, 0);
    filter: blur(3px);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
}

@keyframes hero-copy-exit {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    filter: blur(0);
  }
  to {
    opacity: 0;
    transform: translate3d(-28px, 0, 0);
    filter: blur(2px);
  }
}

.hero-showcase-logo-motion,
.hero-showcase-action-motion,
.hero-showcase-logo-block {
  width: 100%;
  justify-items: center;
}

.hero-showcase-logo-block {
  gap: 9px;
  text-align: center;
  isolation: isolate;
}

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

.hero-showcase-logo-heading,
.hero-showcase-text-title,
.hero-showcase-subtitle {
  position: relative;
  z-index: 2;
  margin: 0;
}

.hero-showcase-logo-heading {
  display: grid;
  justify-items: center;
  width: 100%;
}

.hero-showcase-logo-heading .hero-showcase-text-title {
  display: block;
}

.hero-showcase-action-motion,
.hero-showcase-actions {
  width: 100%;
}

.hero-showcase-text-title {
  max-width: var(--hero-copy-max);
  color: var(--text);
  font-size: clamp(2.05rem, 4.15vw, 3.5rem);
  font-weight: 950;
  line-height: .96;
  letter-spacing: -.055em;
  text-align: center;
  text-wrap: balance;
  text-shadow: 0 14px 30px rgba(0,0,0,.48);
}

.hero-showcase-subtitle {
  max-width: min(24rem, 100%);
  color: rgba(255,255,255,.88);
  font-size: clamp(.75rem, .96vw, .86rem);
  font-weight: 800;
  line-height: 1.32;
  letter-spacing: -.012em;
  text-shadow: 0 2px 12px rgba(0,0,0,.66);
  text-align: center;
  text-wrap: balance;
}

.hero-showcase-actions {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: center;
  margin: 0;
}

.hero-showcase-cta,
.hero-primary-cta {
  position: relative;
  z-index: 4;
  min-width: 148px;
  min-height: 34px;
  padding: 0 18px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 7px;
  color: #f8f8fa;
  background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.08));
  box-shadow: 0 10px 24px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.20);
  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 .15s ease-out;
}

.hero-showcase-cta:hover,
.hero-showcase-cta:focus-visible,
.hero-primary-cta:hover,
.hero-primary-cta:focus-visible {
  color: #f8f8fa;
  border-color: rgba(255,255,255,.25);
  outline-color: rgba(255,255,255,.34);
  outline-offset: var(--carousel-outline-active, .1875rem);
  outline-width: var(--carousel-outline-active, .1875rem);
  background: linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.10));
  transform: translateY(-.125rem);
  box-shadow: 0 10px 24px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.24);
}

.hero-showcase-cta:active,
.hero-primary-cta:active {
  transform: translateY(0);
}

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

.hero-nav-button {
  position: absolute;
  top: 50%;
  display: grid;
  place-items: center;
  width: var(--carousel-control-size, 30px);
  height: var(--carousel-control-size, 30px);
  margin: 0;
  padding: 0;
  border: 0;
  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: var(--carousel-control-shadow, 0 6px 16px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.16));
  outline-color: transparent;
  outline-offset: var(--carousel-outline-idle, .625rem);
  outline-style: solid;
  outline-width: 0;
  opacity: .92;
  transform: translate3d(0, -50%, 0);
  pointer-events: auto;
  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;
}

.hero-nav-button:hover,
.hero-nav-button:focus-visible {
  opacity: 1;
  outline-color: rgba(255,255,255,.35);
  outline-offset: var(--carousel-outline-active, .1875rem);
  outline-width: var(--carousel-outline-active, .1875rem);
  background: var(--carousel-control-bg-hover, rgba(255,255,255,.48));
  transform: translate3d(0, calc(-50% - .125rem), 0) scale(1.035);
}

.hero-nav-button:active {
  transform: translate3d(0, -50%, 0) scale(.985);
}

.hero-nav-button--prev {
  left: max(24px, calc((100vw - var(--hero-frame-width)) / 2 + 8px));
}

.hero-nav-button--next {
  right: max(24px, calc((100vw - var(--hero-frame-width)) / 2 + 8px));
}

.hero-nav-icon,
.hero-nav-icon svg,
.carousel-control-icon,
.carousel-control-icon svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.hero-showcase-pagination {
  position: absolute;
  left: 50%;
  bottom: calc(-1 * var(--hero-pagination-offset));
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  min-height: 36px;
  transform: translate3d(-50%, 0, 0);
  pointer-events: none;
}

.hero-showcase-pagination [data-hero-pagination-shell] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  min-height: 2rem;
  max-width: calc(100vw - 28px);
  padding-block: .25rem;
  padding-inline: .75rem .5rem;
  box-sizing: border-box;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.115);
  border-radius: 999px;
  color: rgba(255,255,255,.94);
  background:
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.025)),
    rgba(16,16,20,.72);
  box-shadow:
    0 12px 28px rgba(0,0,0,.28),
    inset 0 1px 0 rgba(255,255,255,.11);
  backdrop-filter: blur(.75rem) saturate(132%);
  -webkit-backdrop-filter: blur(.75rem) saturate(132%);
  pointer-events: auto;
}

.hero-showcase-pagination [data-hero-pagination-track] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .625rem;
  min-height: 1.5rem;
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
}

.hero-showcase-pagination ._1dfuy4s1 {
  position: relative;
  display: block;
  appearance: none;
  -webkit-appearance: none;
  flex: 0 0 auto;
  cursor: pointer;
  width: .5rem;
  height: .5rem;
  min-width: 0;
  min-height: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.46);
  overflow: hidden;
  opacity: 1;
  transform: translateZ(0);
  transition:
    width .22s cubic-bezier(.2,.8,.2,1),
    background-color .18s ease,
    opacity .18s ease,
    transform .18s ease;
}

.hero-showcase-pagination ._1dfuy4s1:hover,
.hero-showcase-pagination ._1dfuy4s1:focus-visible {
  background: rgba(255,255,255,.72);
  transform: scale(1.08);
}

.hero-showcase-pagination ._1dfuy4s1._1dfuy4s2 {
  width: 3rem;
  background: rgba(255,255,255,.40);
  transform: translateZ(0);
}

.hero-showcase-pagination ._1dfuy4s1._1dfuy4s2::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(255,255,255,.34);
}

.hero-showcase-pagination ._1dfuy4s1._1dfuy4s2::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(255,255,255,.98), rgba(255,255,255,.82));
  box-shadow: 0 0 10px rgba(255,255,255,.16);
  transform: scaleX(0);
  transform-origin: left center;
  animation: hero-autoplay-progress var(--autoplay-duration, 6000ms) linear forwards;
}

.hero-showcase-pagination.is-paused ._1dfuy4s1._1dfuy4s2::after {
  animation-play-state: paused;
}

@keyframes hero-autoplay-progress {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}

.hero-showcase-pagination [data-hero-toggle] {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 1.75rem;
  height: 1.75rem;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: .625rem;
  color: rgba(255,255,255,.96);
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.075)),
    rgba(255,255,255,.08);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 4px 10px rgba(0,0,0,.20);
  cursor: pointer;
  transform: translateZ(0);
  transition:
    color .16s ease,
    background-color .16s ease,
    border-color .16s ease,
    transform .16s ease;
}

.hero-showcase-pagination [data-hero-toggle]:hover,
.hero-showcase-pagination [data-hero-toggle]:focus-visible {
  color: #fff;
  border-color: rgba(255,255,255,.20);
  background:
    linear-gradient(180deg, rgba(255,255,255,.24), rgba(255,255,255,.12)),
    rgba(255,255,255,.12);
  transform: scale(1.035);
}

.hero-showcase-pagination [data-hero-toggle-icon],
.hero-showcase-pagination [data-hero-toggle-icon] svg {
  display: block;
  width: 1rem;
  height: 1rem;
  fill: currentColor;
}

.hero-showcase-bottom-blend {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  z-index: 0;
  height: clamp(138px, 18vw, 254px);
  pointer-events: none;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 18% 100%, rgba(255,255,255,.060), transparent 54%),
    radial-gradient(ellipse at 82% 100%, rgba(255,255,255,.050), transparent 56%),
    linear-gradient(180deg,
      rgba(16,16,20,0) 0%,
      rgba(16,16,20,.10) 20%,
      rgba(16,16,20,.34) 46%,
      rgba(16,16,20,.66) 72%,
      var(--bg) 100%);
}

.hero-showcase-bottom-blend::before,
.hero-showcase-bottom-blend::after {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  pointer-events: none;
}

.hero-showcase-bottom-blend::before {
  bottom: 4%;
  height: 70%;
  background:
    radial-gradient(ellipse at 50% 46%, rgba(255,255,255,.055), rgba(255,255,255,.020) 34%, transparent 68%);
  filter: blur(26px);
  opacity: .72;
}

.hero-showcase-bottom-blend::after {
  bottom: -2px;
  height: 36%;
  background: linear-gradient(180deg, rgba(16,16,20,0), var(--bg) 72%, var(--bg));
}

.discovery-sections.after-hero {
  position: relative;
  z-index: 2;
  margin-top: -1px;
  padding-top: clamp(28px, 3vw, 42px);
  background: transparent;
}

.discovery-sections.after-hero::before {
  content: "";
  position: absolute;
  left: 50%;
  top: clamp(-70px, -5vw, -34px);
  z-index: -1;
  width: 100vw;
  height: clamp(122px, 14vw, 204px);
  pointer-events: none;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(16,16,20,0) 0%, rgba(16,16,20,.40) 26%, rgba(16,16,20,.78) 58%, var(--bg) 86%, var(--bg) 100%);
}

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

.hero-showcase-cta[aria-disabled="true"],
.hero-primary-cta[aria-disabled="true"] {
  cursor: default;
}

.hero-showcase-cta[aria-disabled="true"]:hover,
.hero-primary-cta[aria-disabled="true"]:hover,
.hero-showcase-cta[aria-disabled="true"]:focus-visible,
.hero-primary-cta[aria-disabled="true"]:focus-visible {
  transform: translateZ(0);
}

.hero-showcase[data-hero-controls="hidden"] .hero-nav-button,
.hero-showcase:not([data-hero-controls="visible"]) .hero-nav-button {
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, -50%, 0) scale(.94);
}

.hero-showcase[data-hero-controls="visible"] .hero-nav-button,
.hero-showcase.is-banner-interacted .hero-nav-button,
.hero-showcase:focus-within .hero-nav-button,
.hero-nav-button:focus-visible {
  opacity: .94;
  pointer-events: auto;
  transform: translate3d(0, -50%, 0) scale(1);
}

.hero-showcase[data-hero-controls="visible"] .hero-nav-button:hover,
.hero-showcase[data-hero-controls="visible"] .hero-nav-button:focus-visible,
.hero-showcase.is-banner-interacted .hero-nav-button:hover,
.hero-showcase.is-banner-interacted .hero-nav-button:focus-visible {
  opacity: 1;
  transform: translate3d(0, calc(-50% - .125rem), 0) scale(1.035);
}

.no8po04 { color: var(--no8po02, var(--text)); }
.no8po0b { text-align: center; justify-content: center; }
.no8po0c { max-width: var(--hero-copy-width, calc(50% - 8rem)); }
.no8po0d { text-align: start; justify-content: start; }
.no8po0e { min-height: 32rem; }
.no8po0f { min-height: 40rem; }
.no8po0g { justify-content: flex-end; }
.no8po0i { margin: auto; }
.no8po0t { z-index: -1; }
.no8po0u { opacity: .8; z-index: -2; }
.no8po0v { position: relative; }
.no8po0x { aspect-ratio: 16 / 9; }
.no8po0y { aspect-ratio: 21 / 9; }
.no8po012 { -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 50%, transparent 100%); mask-image: linear-gradient(to bottom, transparent 0%, black 50%, transparent 100%); }
.no8po013 { -webkit-mask-image: linear-gradient(to bottom, black 0%, black 50%, transparent 100%); mask-image: linear-gradient(to bottom, black 0%, black 50%, transparent 100%); }

@media (min-width: 1600px) {
  .hero-showcase {
    --hero-copy-shift: clamp(4rem, 4.6vw, 5.75rem);
    --hero-copy-width: min(32rem, calc(50% - 8.5rem));
    --hero-copy-max: 32rem;
  }

  .hero-showcase-image-mask,
  .no8po0w {
    -webkit-mask-image: linear-gradient(to right, transparent 0%, black 18%, black 78%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, black 18%, black 78%, transparent 100%);
  }
}

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

  .hero-slide[data-hero-ratio-mode="21-9"] .hero-showcase-image-mask,
  .no8po0n {
    inset-inline-start: auto;
    inset-inline-end: var(--hero-art-right-21);
  }
}

@media (max-width: 1279px) {
  .no8po0u {
    display: none;
  }
}

@media (max-width: 1023px) {
  .hero-showcase {
    --hero-pagination-offset: 0px;
    --hero-frame-width: 100%;
    --hero-content-pad: 0px;
    --hero-copy-shift: 0px;
    --hero-copy-width: 100%;
    --hero-copy-max: none;
    --hero-art-right-16: 0px;
    --hero-art-right-21: 0px;
    display: flex;
    flex-direction: column;
    max-width: none;
    min-height: 0;
    margin-bottom: 0;
    padding-block-end: 1.8rem;
    overflow-x: clip;
    background: var(--hero-dark);
  }

  .hero-swiper,
  .hero-swiper-wrapper {
    position: relative;
    inset: auto;
    width: 100%;
    min-height: 0;
    overflow: visible;
  }

  .hero-slide {
    position: absolute;
    inset: 0;
  }

  .hero-slide.is-active {
    position: relative;
    inset: auto;
  }

  .hero-showcase-frame,
  .hero-showcase-layout {
    position: relative;
    inset: auto;
    overflow: visible;
  }

  .hero-showcase-layout {
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
    padding-block-end: 0;
  }

  .hero-showcase-frame::before {
    z-index: 2;
    background:
      linear-gradient(90deg,
        rgba(16,16,20,.48) 0%,
        rgba(16,16,20,.12) 18%,
        rgba(16,16,20,0) 44%,
        rgba(16,16,20,0) 62%,
        rgba(16,16,20,.18) 86%,
        rgba(16,16,20,.52) 100%),
      linear-gradient(180deg,
        rgba(16,16,20,.30) 0%,
        rgba(16,16,20,0) 18%,
        rgba(16,16,20,0) 58%,
        rgba(16,16,20,.52) 86%,
        var(--bg) 100%);
  }

  .hero-showcase-frame::after {
    display: none;
  }

  .hero-showcase-art {
    position: relative;
    inset: auto;
    width: 100%;
    aspect-ratio: var(--hero-slide-ratio, var(--hero-active-ratio));
    min-height: 0;
    overflow: hidden;
  }

  .hero-showcase-image-shell,
  .hero-showcase-backdrop,
  .hero-showcase-backdrop::after {
    position: absolute;
    inset: 0;
  }

  .hero-showcase-backdrop {
    left: 0;
    width: 100%;
    transform: none;
  }

  .hero-showcase-backdrop::before {
    inset: -10%;
    filter: blur(1.9rem) saturate(1.16) brightness(.76);
    opacity: .18;
  }

  .hero-showcase-image-shell::before {
    background:
      linear-gradient(180deg,
        var(--hero-dark) 0%,
        rgba(16,16,20,.36) 5%,
        rgba(16,16,20,0) 18%,
        rgba(16,16,20,0) 48%,
        rgba(16,16,20,.20) 64%,
        rgba(16,16,20,.58) 82%,
        var(--bg) 100%);
  }

  .hero-showcase-image-shell::after {
    background:
      linear-gradient(90deg,
        rgba(16,16,20,.36) 0%,
        rgba(16,16,20,.08) 18%,
        rgba(16,16,20,0) 54%,
        rgba(16,16,20,.22) 100%);
    opacity: .62;
  }

  .hero-showcase-image-mask,
  .hero-slide[data-hero-ratio-mode="21-9"] .hero-showcase-image-mask,
  .hero-slide:not([data-hero-ratio-mode="21-9"]) .hero-showcase-image-mask,
  .hero-slide[data-hero-image-only="true"] .hero-showcase-image-mask,
  .no8po0k {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    max-width: none;
    aspect-ratio: auto;
    transform: translateZ(0);
    transform-origin: center 25%;
    -webkit-mask-image: linear-gradient(to bottom, black 0%, black 75%, transparent 100%);
    mask-image: linear-gradient(to bottom, black 0%, black 75%, transparent 100%);
  }

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

  .hero-showcase-art::after {
    background:
      linear-gradient(90deg, rgba(16,16,20,.64) 0%, rgba(16,16,20,.24) 22%, rgba(16,16,20,.08) 72%, rgba(16,16,20,.42) 100%),
      linear-gradient(180deg, rgba(16,16,20,.00) 0%, rgba(16,16,20,.04) 42%, rgba(16,16,20,.30) 68%, rgba(16,16,20,.70) 88%, var(--bg) 100%);
  }

  .hero-showcase-copy-area {
    position: relative;
    inset: auto;
    z-index: 14;
    display: flex;
    width: 100%;
    height: auto;
    min-height: 0;
    margin-top: 0;
    padding: 16px 0 4px;
    background: var(--bg);
    pointer-events: auto;
  }

  .hero-showcase-copy-shell {
    width: min(100% - 32px, 44rem);
    height: auto;
    margin-inline: auto;
    padding: .9rem 0 0;
    justify-items: center;
  }

  .hero-showcase-copy,
  .no8po0h {
    width: 100%;
    max-width: none;
  }

  .hero-showcase-copy-stack,
  .hero-showcase-logo-motion,
  .hero-showcase-action-motion,
  .hero-showcase-logo-block,
  .hero-showcase-logo-heading {
    justify-items: center;
  }

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

  .hero-showcase-copy-stack {
    gap: 12px;
  }

  .hero-showcase-text-title {
    max-width: 32rem;
    font-size: clamp(1.55rem, 7vw, 2.25rem);
    text-align: center;
  }

  .hero-showcase-subtitle {
    max-width: 32rem;
    font-size: .78rem;
    line-height: 1.34;
    text-align: center;
  }

  .hero-showcase-cta,
  .hero-primary-cta {
    min-width: 142px;
    min-height: 31px;
    padding-inline: 15px;
    border-radius: 7px;
    font-size: 11px;
  }

  .hero-nav-controls {
    inset: 0 0 auto;
    height: var(--hero-mobile-media-height);
    max-height: 56.25vw;
  }

  .hero-nav-button {
    width: var(--carousel-control-size, 30px);
    height: var(--carousel-control-size, 30px);
    opacity: .88;
  }

  .hero-nav-button--prev {
    left: 14px;
  }

  .hero-nav-button--next {
    right: 14px;
  }

  .hero-showcase-pagination {
    position: relative;
    left: auto;
    top: auto;
    bottom: auto;
    z-index: 30;
    order: 3;
    width: 100%;
    margin: 20px auto 0;
    transform: none;
  }

  .hero-showcase-bottom-blend {
    top: calc(var(--hero-mobile-media-height) - 112px);
    bottom: auto;
    z-index: 0;
    height: 132px;
  }
}

@media (max-width: 560px) {
  .hero-showcase {
    padding-block-end: 1.65rem;
  }

  .hero-showcase-copy-shell {
    width: calc(100% - 28px);
    padding-top: .78rem;
  }

  .hero-showcase-text-title {
    max-width: 100%;
    font-size: clamp(1.38rem, 7.4vw, 1.92rem);
  }

  .hero-showcase-subtitle {
    max-width: 100%;
    font-size: .72rem;
  }

  .hero-nav-button {
    top: 50%;
    width: 28px;
    height: 28px;
    border-radius: var(--carousel-control-radius, 7px);
  }

  .hero-nav-button:hover,
  .hero-nav-button:focus-visible {
    transform: translate3d(0, -50%, 0);
  }

  .hero-showcase-pagination {
    margin-top: 18px;
  }

  .hero-showcase-pagination [data-hero-pagination-shell] {
    max-width: calc(100vw - 22px);
    gap: .4rem;
    padding-block: .25rem;
    padding-inline: .625rem .45rem;
  }

  .hero-showcase-pagination [data-hero-pagination-track] {
    gap: .5rem;
  }

  .hero-showcase-pagination ._1dfuy4s1 {
    width: .375rem;
    height: .375rem;
  }

  .hero-showcase-pagination ._1dfuy4s1._1dfuy4s2 {
    width: 2rem;
    height: .375rem;
  }

  .hero-showcase-pagination [data-hero-toggle] {
    width: 1.55rem;
    height: 1.55rem;
    border-radius: .55rem;
  }

  .hero-showcase-pagination [data-hero-toggle-icon],
  .hero-showcase-pagination [data-hero-toggle-icon] svg {
    width: .875rem;
    height: .875rem;
  }
}

@media (max-width: 390px) {
  .hero-showcase-pagination {
    margin-top: 16px;
  }

  .hero-showcase-copy-shell {
    width: calc(100% - 24px);
  }

  .hero-showcase-cta,
  .hero-primary-cta {
    min-width: 132px;
    min-height: 29px;
    font-size: 10.5px;
  }

  .hero-nav-button {
    width: 26px;
    height: 26px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-slide,
  .hero-showcase-image,
  .hero-showcase-copy-stack,
  .hero-nav-button,
  .hero-showcase-pagination ._1dfuy4s1,
  .hero-showcase-pagination [data-hero-toggle] {
    transition: none;
    animation: none;
  }

  .hero-showcase-pagination ._1dfuy4s1._1dfuy4s2::before,
  .hero-showcase-pagination ._1dfuy4s1._1dfuy4s2::after {
    animation: none;
    transform: scaleX(1);
  }

  .hero-nav-button {
    transition-duration: .01ms;
  }
}

/* === header.css === */
.site-header,
.global-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 90;
  height: var(--header-h);
  border-bottom: 1px solid var(--header-glass-border, rgba(255,255,255,.10));
  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: 0 14px 42px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.08);
  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: var(--header-glass-border-strong, rgba(255,255,255,.15));
  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: 0 18px 48px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.10);
}

.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: var(--header-control-border, var(--line));
  background: var(--header-control-bg, var(--glass-bg));
  box-shadow: 0 1px 0 rgba(255,255,255,.08) inset;
  backdrop-filter: blur(14px) saturate(136%);
  -webkit-backdrop-filter: blur(14px) saturate(136%);
}

.header-search-form .search:hover,
.header-search-form .search:focus-within {
  border-color: var(--header-control-border-hover, var(--line-strong));
  background: var(--header-control-bg-hover, var(--glass-bg-strong));
  box-shadow: 0 1px 0 rgba(255,255,255,.10) inset, var(--header-focus-ring, 0 0 0 2px rgba(255,255,255,.12));
}

.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 === */
/* Balanced rail edge, soft right shadow, and fixed game-card media geometry. */
:root {
  --rail-edge-gutter: clamp(10px, 2vw, 20px);
  --rail-card-safe-space: clamp(14px, 1.9vw, 24px);
  --rail-control-inset: clamp(6px, .85vw, 14px);
  --rail-control-fallback-y: clamp(68px, 6.2vw, 82px);
  --rail-edge-soft-width: clamp(18px, 3.6vw, 48px);
}

.featured-carousel-stage,
.content-row-stage,
.news-carousel-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 {
  -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: var(--rail-card-safe-space) calc(var(--rail-card-safe-space) + var(--rail-edge-soft-width)) calc(var(--rail-card-safe-space) + 8px) var(--rail-card-safe-space);
  margin-left: 0;
}

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

.featured-carousel-stage::after,
.content-row-stage::after,
.news-carousel-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(90deg,
    color-mix(in srgb, var(--bg) 0%, transparent) 0%,
    color-mix(in srgb, var(--bg) 42%, transparent) 64%,
    color-mix(in srgb, var(--bg) 88%, transparent) 100%);
  box-shadow: inset -10px 0 18px color-mix(in srgb, #000 12%, transparent);
}

.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: 12px;
  padding-right: calc(var(--rail-edge-soft-width) + 8px);
  margin-bottom: 10px;
}

.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 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 36%, transparent);
  border-radius: 999px;
  color: color-mix(in srgb, var(--accent) 82%, #fff 18%);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent) 18%, transparent),
    color-mix(in srgb, var(--surface-2) 88%, transparent));
  box-shadow:
    0 8px 18px color-mix(in srgb, #000 18%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 10%, transparent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .01em;
  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, box-shadow .18s ease;
}

.section-action-link::after {
  content: "›";
  margin-left: 7px;
  font-size: 18px;
  line-height: .7;
}

.section-action-link:hover,
.section-action-link:focus-visible {
  border-color: color-mix(in srgb, var(--accent) 58%, transparent);
  color: #fff;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent) 28%, transparent),
    color-mix(in srgb, var(--surface-2) 84%, transparent));
  box-shadow:
    0 10px 22px color-mix(in srgb, #000 20%, transparent),
    inset 0 1px 0 color-mix(in srgb, #fff 12%, transparent);
  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;
}

.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: linear-gradient(180deg, color-mix(in srgb, var(--surface) 88%, transparent), color-mix(in srgb, var(--surface-2) 82%, transparent));
  box-shadow: 0 14px 34px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.07);
}

.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(56px, auto) auto;
  align-content: start;
  gap: 12px;
  min-height: 132px;
  height: 100%;
  padding: 16px;
}

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

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

.spotlight-card-title-text {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  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 {
  display: block;
  color: var(--subtle);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}

@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(18px, 6vw, 32px);
  }

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

  .api-spotlight-head {
    margin-bottom: 12px;
  }

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

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

  .section-head--with-action h2 {
    font-size: clamp(24px, 7.5vw, 34px);
  }

  .section-action-link {
    min-height: 32px;
    padding: 0 12px;
    font-size: 11px;
  }

  .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(48px, auto) auto;
    min-height: 116px;
    padding: 13px;
  }

  .spotlight-card-title {
    min-height: 48px;
    font-size: 16px;
  }
}


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

/* === 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;
  background:
    radial-gradient(circle at 50% -12%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 34rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 92%, #000), var(--bg) 38rem);
}

.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;
  background:
    linear-gradient(180deg, rgba(4, 8, 14, .36) 0%, rgba(4, 8, 14, .78) 48%, var(--bg) 100%),
    radial-gradient(circle at 76% 10%, color-mix(in srgb, var(--accent-2) 20%, transparent), transparent 28rem);
}

.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;
  background:
    radial-gradient(circle at 50% -20%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 32rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 94%, #000), var(--bg));
}

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

/* === 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;
  background:
    radial-gradient(circle at 9% 2%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 26rem),
    radial-gradient(circle at 82% 10%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 28rem),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 94%, #000), var(--bg) 34rem);
}

.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;
  background:
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,0)),
    radial-gradient(circle at 74% 12%, color-mix(in srgb, var(--accent-2) 17%, transparent), transparent 24rem);
}

.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;
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 28rem),
    radial-gradient(circle at 86% 10%, color-mix(in srgb, var(--accent-2) 12%, transparent), transparent 26rem),
    var(--bg);
}

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

/* === 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);
  background:
    radial-gradient(circle at 18% 0%, color-mix(in srgb, var(--accent) 10%, transparent), transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--surface) 42%, transparent), color-mix(in srgb, var(--bg) 96%, transparent));
  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;
  }
}
