.sp-gx-landing {
  --gx-raisin-black-1: var(--gt-bg-2, #1c1d20);
  --gx-raisin-black-2: var(--gt-bg-2, #1c1d20);
  --gx-raisin-black-3: #25262c;
  --gx-eerie-black: var(--gt-bg, #0b0e13);
  --gx-light-gray: var(--gt-text, #ababab);
  --gx-platinum: hsl(0, 4%, 91%);
  --gx-xiketic: #14151a;
  --gx-accent: var(--gt-theme, #ff0808);
  --gx-white: var(--gt-white, #fff);
  --gx-onyx: hsl(240, 5%, 26%);
  --gx-ff-heading: "Chakra Petch", sans-serif;
  --gx-ff-body: "Chakra Petch", sans-serif;
  --gx-fs-1: clamp(42px, 12vw, 150px);
  --gx-fs-2: clamp(26px, 5vw, 45px);
  --gx-fs-3: clamp(24px, 4vw, 36px);
  --gx-fs-4: 26px;
  --gx-fs-5: 22px;
  --gx-fs-6: 20px;
  --gx-fs-7: 18px;
  --gx-fs-8: 15px;
  --gx-fs-9: 14px;
  --gx-fs-10: 13px;
  --gx-fs-11: 12px;
  --gx-fw-400: 400;
  --gx-fw-500: 500;
  --gx-fw-700: 700;
  --gx-transition-1: 0.15s ease-in-out;
  --gx-transition-2: 0.15s ease-in;
  --gx-transition-3: 0.25s ease-out;
  --gx-section-padding: 60px;
  --gx-polygon-1: polygon(90% 0, 100% 34%, 100% 100%, 10% 100%, 0 66%, 0 0);
  --gx-polygon-2: polygon(0 0, 100% 0%, 82% 100%, 0% 100%);
  --gx-polygon-3: polygon(0 0, 100% 0%, 100% 100%, 18% 100%);
  --gx-polygon-4: polygon(96% 0, 100% 36%, 100% 100%, 4% 100%, 0 66%, 0 0);

  font-family: var(--gx-ff-body);
  color: var(--gx-white);
  background: var(--gx-eerie-black);
  overflow-x: hidden;
}

.sp-gx-landing *,
.sp-gx-landing *::before,
.sp-gx-landing *::after {
  box-sizing: border-box;
}

.sp-gx-landing a {
  text-decoration: none;
  color: inherit;
}

.sp-gx-landing .gx-container {
  padding-inline: 15px;
  max-width: 1200px;
  margin-inline: auto;
}

.sp-gx-landing .gx-h1 {
  color: var(--gx-white);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-1);
  font-weight: var(--gx-fw-700);
  text-transform: uppercase;
  line-height: 0.95;
  letter-spacing: 0.02em;
  margin: 0 0 10px;
}

.sp-gx-landing .gx-h2 {
  font-size: var(--gx-fs-2);
  color: var(--gx-white);
  line-height: 1.2;
  text-transform: uppercase;
  font-family: var(--gx-ff-heading);
  font-weight: var(--gx-fw-600);
  margin: 0;
}

.sp-gx-landing .gx-h3 {
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-2);
  text-transform: uppercase;
  line-height: 1.2;
  margin: 0;
}

.sp-gx-landing .gx-section-title {
  position: relative;
  text-align: center;
  margin-bottom: 80px;
}

.sp-gx-landing .gx-section-title::before,
.sp-gx-landing .gx-section-title::after {
  content: "";
  position: absolute;
  bottom: -20px;
  left: 50%;
  transform: translateX(-50%);
  height: 5px;
  width: 120px;
  background: var(--gx-accent);
  border-radius: 0 0 5px 5px;
}

.sp-gx-landing .gx-section-title::before {
  bottom: -23px;
  height: 4px;
  width: 30px;
}

.sp-gx-landing a.gt-theme-btn,
.sp-gx-landing button.gt-theme-btn {
  min-width: 0 !important;
  text-decoration: none;
  box-sizing: border-box;
}

.sp-gx-landing .sp-gx-landing__btn {
  min-width: 0 !important;
  white-space: nowrap;
}

.sp-gx-landing .sp-gx-landing__btn--border {
  min-width: 0 !important;
}

.sp-gx-landing .sp-gx-landing__btn--compact {
  padding: 14px 20px !important;
  font-size: 15px !important;
}

.sp-gx-landing .sp-gx-landing__btn--icon {
  min-width: 48px !important;
  width: 48px;
  height: 48px;
  padding: 0 !important;
}

.sp-gx-landing .gx-btn-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px;
}

/* Footer logo (marketing blocks) */
.sp-gx-landing .gx-logo img {
  display: block;
  max-height: 44px;
  width: auto;
}

/* —— Hero —— */
.sp-gx-landing .gx-hero {
  position: relative;
  isolation: isolate;
  margin-top: 0;
  /* Espace sous la barre absolue (même principe que le hub dashboard) */
  padding: max(5.75rem, calc(env(safe-area-inset-top, 0px) + 4.75rem)) 0 var(--gx-section-padding);
  min-height: 100vh;
  max-height: 1000px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  background-color: var(--gx-eerie-black);
  overflow: hidden;
}

.sp-gx-landing .gx-hero__slides {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.sp-gx-landing .gx-hero__slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
}

.sp-gx-landing .gx-hero__slide--active {
  opacity: 1;
}

.sp-gx-landing .gx-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background-image:
    linear-gradient(180deg, hsla(0, 0%, 0%, 0.5) 0%, hsla(11, 14%, 8%, 0.88) 100%),
    radial-gradient(ellipse 85% 55% at 50% 15%, hsla(0, 100%, 50%, 0.22), transparent 55%);
}

.sp-gx-landing .gx-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
}

.sp-gx-landing .gx-hero-subtitle {
  color: var(--gx-white);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-7);
  font-weight: var(--gx-fw-500);
  text-transform: uppercase;
  letter-spacing: 0.35em;
  text-shadow: 0 7px hsla(0, 0%, 0%, 0.4);
  margin-bottom: 15px;
}

/* —— Section wrapper —— */
.sp-gx-landing .gx-section-wrapper {
  background-color: var(--gx-eerie-black);
  background-image:
    linear-gradient(180deg, rgba(11, 14, 19, 0.94) 0%, rgba(11, 14, 19, 0.98) 100%),
    radial-gradient(circle at 20% 20%, hsla(0, 100%, 50%, 0.06), transparent 45%),
    var(--gx-section-bg, none);
  background-size: cover;
  background-position: center;
  background-attachment: scroll;
}

/* —— About —— */
.sp-gx-landing .gx-about {
  padding: 100px 0 var(--gx-section-padding);
}

.sp-gx-landing .gx-about-banner {
  margin-bottom: 40px;
  position: relative;
  max-width: 410px;
  margin-inline: auto;
}

.sp-gx-landing .gx-about-img {
  width: 100%;
  display: block;
  border-radius: 8px;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid hsla(0, 0%, 100%, 0.08);
  box-shadow: 0 12px 40px hsla(0, 0%, 0%, 0.35);
}

.sp-gx-landing .gx-about-content {
  background: var(--gx-raisin-black-1);
  color: var(--gx-white);
  padding: 40px 20px;
  border-radius: 4px;
  box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2);
}

.sp-gx-landing .gx-about-subtitle {
  color: var(--gx-accent);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-8);
  font-weight: var(--gx-fw-500);
  text-transform: uppercase;
  margin-bottom: 15px;
}

.sp-gx-landing .gx-about-title {
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-2);
  line-height: 1.2;
  text-transform: uppercase;
  margin-bottom: 20px;
}

.sp-gx-landing .gx-about-title strong {
  color: var(--gx-accent);
}

.sp-gx-landing .gx-about-text,
.sp-gx-landing .gx-about-bottom-text {
  color: var(--gx-light-gray);
  font-size: var(--gx-fs-9);
  line-height: 1.8;
  letter-spacing: 0.5px;
}

.sp-gx-landing .gx-about-text {
  margin-bottom: 20px;
}

.sp-gx-landing .gx-about-bottom-text {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}

.sp-gx-landing .gx-about-bottom-text i {
  color: var(--gx-accent);
  font-size: 22px;
  margin-top: 2px;
}

/* —— Tournament —— */
.sp-gx-landing .gx-tournament {
  padding: var(--gx-section-padding) 0;
  color: var(--gx-white);
  text-align: center;
}

.sp-gx-landing .gx-tournament-content {
  margin-bottom: 50px;
}

.sp-gx-landing .gx-tournament-subtitle {
  color: var(--gx-accent);
  font-family: var(--gx-ff-heading);
  font-weight: var(--gx-fw-500);
  text-transform: uppercase;
  margin-bottom: 10px;
}

.sp-gx-landing .gx-tournament-title {
  margin-bottom: 20px;
}

.sp-gx-landing .gx-tournament-text {
  color: var(--gx-light-gray);
  font-size: var(--gx-fs-9);
  line-height: 1.8;
  margin-bottom: 30px;
}

.sp-gx-landing .gx-tournament .sp-holo-cta {
  width: max-content;
  margin-inline: auto;
}

.sp-gx-landing .gx-tournament-prize {
  margin-bottom: 50px;
}

.sp-gx-landing .gx-tournament-prize-title {
  font-size: var(--gx-fs-3);
  margin-bottom: 20px;
}

.sp-gx-landing .gx-prize-badge {
  display: inline-block;
  background: var(--gx-accent);
  color: var(--gx-white);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-4);
  padding: 8px 42px;
  border-radius: 50px;
  font-weight: var(--gx-fw-700);
}

.sp-gx-landing .gx-tournament-prize figure {
  margin: 24px 0 0;
}

.sp-gx-landing .gx-tournament-prize img {
  width: 100%;
  max-width: 320px;
  margin-inline: auto;
  display: block;
  border-radius: 8px;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border: 1px solid hsla(0, 0%, 100%, 0.08);
}

.sp-gx-landing .gx-tournament-winners {
  background: var(--gx-raisin-black-1);
  padding: 40px 30px;
  border-radius: 4px;
  box-shadow: 0 2px 4px hsla(0, 0%, 0%, 0.2);
}

.sp-gx-landing .gx-tournament-winners-title {
  font-size: var(--gx-fs-3);
  margin-bottom: 25px;
}

.sp-gx-landing .gx-tournament-winners-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 20px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.sp-gx-landing .gx-winner-card__thumb {
  width: 90px;
  height: 90px;
  margin-inline: auto;
  margin-bottom: 15px;
  border-radius: 50%;
  overflow: hidden;
  border: 3px solid var(--gx-raisin-black-3);
  box-shadow: 0 4px 16px hsla(0, 0%, 0%, 0.35);
}

.sp-gx-landing .gx-winner-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sp-gx-landing .gx-winner-card .gx-card-title {
  background: var(--gx-accent);
  width: max-content;
  margin-inline: auto;
  font-size: var(--gx-fs-10);
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 4px;
  font-family: var(--gx-ff-heading);
}

.sp-gx-landing .gx-tournament-winners--admin .gx-tournament-winners__hint {
  color: var(--gx-light-gray);
  font-size: var(--gx-fs-9);
  line-height: 1.5;
  margin: -12px 0 20px;
  text-align: center;
}

.sp-gx-landing .gx-tournament-winners__state {
  text-align: center;
  margin-bottom: 0;
}

.sp-gx-landing .gx-tournament-admin-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.sp-gx-landing .gx-admin-match-card {
  display: flex;
  align-items: stretch;
  gap: 14px;
  text-align: left;
  text-decoration: none !important;
  color: inherit !important;
  background: rgba(0, 0, 0, 0.2);
  border: 1px solid hsla(0, 0%, 100%, 0.08);
  border-radius: 10px;
  overflow: hidden;
  transition: border-color var(--gx-transition-1), background var(--gx-transition-1);
}

.sp-gx-landing .gx-admin-match-card:hover {
  border-color: hsla(0, 100%, 50%, 0.35);
  background: rgba(0, 0, 0, 0.35);
}

.sp-gx-landing .gx-admin-match-card__media {
  position: relative;
  flex: 0 0 108px;
  min-height: 88px;
  background: var(--gx-raisin-black-3);
}

.sp-gx-landing .gx-admin-match-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sp-gx-landing .gx-admin-match-card__badge {
  position: absolute;
  top: 6px;
  left: 6px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(11, 14, 19, 0.85);
  color: var(--gx-white);
}

.sp-gx-landing .gx-admin-match-card__badge--live {
  background: rgba(220, 38, 38, 0.92);
}

.sp-gx-landing .gx-admin-match-card__badge--upcoming {
  color: var(--gx-eerie-black);
  background: var(--gx-accent);
}

.sp-gx-landing .gx-admin-match-card__badge--completed {
  background: rgba(100, 100, 110, 0.9);
}

.sp-gx-landing .gx-admin-match-card__body {
  flex: 1;
  min-width: 0;
  padding: 10px 12px 10px 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
}

.sp-gx-landing .gx-admin-match-card__title {
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-8);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.25;
  margin: 0;
  color: var(--gx-white);
}

.sp-gx-landing .gx-admin-match-card__meta,
.sp-gx-landing .gx-admin-match-card__time {
  margin: 0;
  font-size: var(--gx-fs-10);
  color: var(--gx-light-gray);
  line-height: 1.35;
}

.sp-gx-landing .gx-admin-match-card__time {
  color: rgba(255, 255, 255, 0.72);
}

/* —— Gallery (Swiper, align dashboard gt-gallery-slider) —— */
.sp-gx-landing .gx-gallery.gt-tournament-gallery-section.fix {
  overflow: visible !important;
}

.sp-gx-landing .gx-gallery .gx-container {
  margin-bottom: clamp(18px, 3vw, 28px);
}

.sp-gx-landing .gx-gallery .gt-epic-gallery-item {
  margin-bottom: 0;
}

.sp-gx-landing .gx-gallery .gt-epic-gallery-item.gt-style-2 {
  margin-top: 0;
}

.sp-gx-landing .gx-gallery .gt-gallery-iamge {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  border: 1px solid hsla(0, 0%, 100%, 0.08);
  box-shadow: 0 8px 28px hsla(0, 0%, 0%, 0.35);
}

.sp-gx-landing .gx-gallery .gt-gallery-iamge img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.sp-gx-landing .sp-gx-landing-gallery__swiper.gt-gallery-slider {
  margin-left: -12%;
  margin-right: -12%;
}

@media (max-width: 1199px) {
  .sp-gx-landing .sp-gx-landing-gallery__swiper.gt-gallery-slider {
    margin-left: 0;
    margin-right: 0;
  }
}

/* —— Team / community —— */
.sp-gx-landing .gx-team {
  padding: var(--gx-section-padding) 0;
}

.sp-gx-landing .gx-team-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 30px;
  margin: 0 0 50px;
  padding: 0;
  list-style: none;
}

.sp-gx-landing .gx-team-list > li {
  max-width: 40%;
}

.sp-gx-landing .gx-team-member {
  position: relative;
  border-radius: 50%;
  border: 3px solid var(--gx-raisin-black-3);
  transition: var(--gx-transition-1);
  display: block;
  overflow: hidden;
  aspect-ratio: 1;
}

.sp-gx-landing .gx-team-member:hover {
  border-color: var(--gx-accent);
}

.sp-gx-landing .gx-team-member figure {
  margin: 0;
  width: 100%;
  height: 100%;
}

.sp-gx-landing .gx-team-member img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sp-gx-landing .gx-team-member i {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--gx-accent);
  font-size: 28px;
  opacity: 0;
  transition: var(--gx-transition-1);
  pointer-events: none;
}

.sp-gx-landing .gx-team-member:hover i {
  opacity: 1;
}

.sp-gx-landing .gx-team .sp-holo-cta {
  margin-inline: auto;
  display: inline-block;
}

/* —— Features (gears) —— */
.sp-gx-landing .gx-gears {
  padding: var(--gx-section-padding) 0;
}

.sp-gx-landing .gx-gears-list {
  display: grid;
  gap: 50px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.sp-gx-landing .gx-gears-card .gx-card-banner {
  position: relative;
  isolation: isolate;
  width: 100%;
  aspect-ratio: 2 / 1.7;
  display: grid;
  place-items: center;
  margin-bottom: 30px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid hsla(0, 0%, 100%, 0.08);
  background-color: var(--gx-raisin-black-2);
  background-image: linear-gradient(180deg, rgba(11, 14, 19, 0.2) 0%, rgba(11, 14, 19, 0.82) 100%), var(--gx-card-bg, none);
  background-size: cover;
  background-position: center;
}

.sp-gx-landing .gx-gears-card .gx-card-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 80%, hsla(0, 100%, 50%, 0.12), transparent 55%);
  z-index: 0;
  pointer-events: none;
}

.sp-gx-landing .gx-gears-card .gx-card-banner__icon {
  position: relative;
  z-index: 1;
  width: min(44%, 100px);
  height: auto;
  filter: drop-shadow(0 6px 20px hsla(0, 0%, 0%, 0.55));
}

.sp-gx-landing .gx-gears .gx-card-content {
  color: var(--gx-white);
  margin-bottom: 25px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  text-transform: uppercase;
}

.sp-gx-landing .gx-gears-card .gx-card-title {
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-5);
  font-weight: var(--gx-fw-700);
  margin-bottom: 5px;
}

.sp-gx-landing .gx-gears-card .gx-card-subtitle {
  color: var(--gx-light-gray);
  font-size: var(--gx-fs-8);
  text-transform: none;
}

.sp-gx-landing .gx-gears-card .gx-card-actions {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
}


/* —— Newsletter / CTA —— */
.sp-gx-landing .gx-newsletter {
  padding: var(--gx-section-padding) 0 100px;
}

.sp-gx-landing .gx-newsletter-card {
  background-color: var(--gx-raisin-black-2);
  background-image:
    linear-gradient(135deg, hsla(0, 100%, 50%, 0.18) 0%, transparent 55%),
    linear-gradient(180deg, rgba(11, 14, 19, 0.85) 0%, rgba(11, 14, 19, 0.94) 100%),
    var(--gx-newsletter-bg, none);
  background-size: cover;
  background-position: center;
  padding: 50px 25px;
  border-radius: 12px;
  text-align: center;
  border: 1px solid hsla(0, 0%, 100%, 0.08);
}

.sp-gx-landing .gx-newsletter-content {
  margin-bottom: 30px;
}

.sp-gx-landing .gx-newsletter-img {
  width: max-content;
  margin-inline: auto;
  margin-bottom: 10px;
}

.sp-gx-landing .gx-newsletter-img img {
  max-height: 80px;
  width: auto;
}

.sp-gx-landing .gx-newsletter-title {
  font-size: var(--gx-fs-3);
}

.sp-gx-landing .gx-newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 480px;
  margin-inline: auto;
}

.sp-gx-landing .gx-newsletter .gx-input-field {
  background: hsla(0, 0%, 0%, 0.2);
  color: var(--gx-white);
  border: 1px solid var(--gx-white);
  font-size: var(--gx-fs-10);
  padding: 17px 25px;
  width: 100%;
  border-radius: 4px;
}

.sp-gx-landing .gx-newsletter .gx-input-field:focus {
  outline: none;
  background: hsla(0, 0%, 0%, 0.35);
}

.sp-gx-landing .gx-newsletter .gx-input-field::placeholder {
  color: hsla(0, 0%, 100%, 0.55);
}

.sp-gx-landing .gx-newsletter-msg {
  flex-basis: 100%;
  margin: 0;
  color: var(--gx-light-gray);
  font-size: var(--gx-fs-9);
}

/* —— Footer —— */
.sp-gx-landing .gx-footer-top {
  background: linear-gradient(180deg, var(--gx-raisin-black-2) 0%, var(--gx-eerie-black) 100%);
  padding: var(--gx-section-padding) 0;
  border-top: 1px solid hsla(0, 0%, 100%, 0.06);
}

.sp-gx-landing .gx-footer-brand-wrapper {
  position: relative;
  padding-bottom: 30px;
  border-bottom: 1px solid hsl(220, 14%, 8%);
  margin-bottom: 50px;
}

.sp-gx-landing .gx-footer-brand-wrapper::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: hsla(0, 0%, 50%, 0.2);
}

.sp-gx-landing .gx-footer-top .gx-logo {
  width: max-content;
  margin-inline: auto;
  margin-bottom: 50px;
  display: block;
}

.sp-gx-landing .gx-footer-menu-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 5px 40px;
  margin-bottom: 20px;
  list-style: none;
  padding: 0;
}

.sp-gx-landing .gx-footer-menu-link {
  color: var(--gx-platinum);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-8);
  font-weight: var(--gx-fw-500);
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 10px;
  transition: var(--gx-transition-1);
}

.sp-gx-landing .gx-footer-menu-link:hover {
  color: var(--gx-accent);
}

.sp-gx-landing .gx-footer-quicklinks {
  text-align: center;
}

.sp-gx-landing .gx-quicklink-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px 20px;
  margin-bottom: 20px;
  list-style: none;
  padding: 0;
}

.sp-gx-landing .gx-quicklink-item {
  color: var(--gx-light-gray);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-11);
  font-weight: var(--gx-fw-500);
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 5px 10px;
  transition: var(--gx-transition-1);
}

.sp-gx-landing .gx-quicklink-item:hover {
  color: var(--gx-accent);
}

.sp-gx-landing .gx-footer-social-list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.sp-gx-landing .gx-footer-social-link {
  background: var(--gx-xiketic);
  color: var(--gx-light-gray);
  width: 35px;
  height: 35px;
  display: grid;
  place-items: center;
  font-size: 14px;
  border-radius: 50%;
  transition: var(--gx-transition-1);
}

.sp-gx-landing .gx-footer-social-link:hover {
  color: var(--gx-accent);
}

.sp-gx-landing .gx-footer-bottom {
  padding: 25px 0;
  background: var(--gx-xiketic);
  text-align: center;
}

.sp-gx-landing .gx-copyright {
  color: var(--gx-light-gray);
  font-family: var(--gx-ff-heading);
  font-size: var(--gx-fs-9);
  font-weight: var(--gx-fw-500);
  text-transform: uppercase;
  margin: 0;
}

.sp-gx-landing .gx-copyright a {
  display: inline;
  color: var(--gx-accent);
}

/* —— Go top —— */
.sp-gx-landing .gx-go-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  padding: 15px;
  z-index: 40;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transition: var(--gx-transition-1);
}

.sp-gx-landing .gx-go-top.gx-visible {
  visibility: visible;
  opacity: 1;
  pointer-events: all;
}

.sp-gx-landing .gx-go-top:hover .sp-mk8-cta__btn {
  transform: scale(1.06);
}

/* —— Responsive: 575px —— */
@media (min-width: 575px) {
  .sp-gx-landing .gx-container {
    max-width: 540px;
  }

  .sp-gx-landing .gx-about-banner {
    max-width: 430px;
  }

  .sp-gx-landing .gx-about-content {
    padding: 60px 40px;
  }

  .sp-gx-landing .gx-tournament-text {
    max-width: 500px;
    margin-inline: auto;
  }

}

/* —— Responsive: 768px —— */
@media (min-width: 768px) {
  .sp-gx-landing .gx-container {
    max-width: 700px;
  }

  .sp-gx-landing .gx-hero-subtitle {
    font-size: 25px;
    letter-spacing: 0.5em;
  }

  .sp-gx-landing .gx-gears-list {
    grid-template-columns: 1fr 1fr;
  }

  .sp-gx-landing .gx-newsletter-card {
    text-align: left;
  }

  .sp-gx-landing .gx-newsletter-content {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
    max-width: 440px;
    margin-inline: auto;
    margin-bottom: 30px;
  }

  .sp-gx-landing .gx-newsletter-img {
    margin-inline: 0;
  }

  .sp-gx-landing .gx-footer-menu-wrapper,
  .sp-gx-landing .gx-footer-quicklinks,
  .sp-gx-landing .gx-footer-bottom .gx-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .sp-gx-landing .gx-footer-menu-list {
    max-width: 50%;
    justify-content: flex-start;
    column-gap: 16px;
    margin-bottom: 0;
  }

  .sp-gx-landing .gx-quicklink-list {
    margin-bottom: 0;
  }
}

/* —— Responsive: 1024px —— */
@media (min-width: 1024px) {
  .sp-gx-landing {
    --gx-section-padding: 100px;
  }

  .sp-gx-landing .gx-container {
    max-width: 1000px;
  }

  .sp-gx-landing .gx-about {
    padding-top: 160px;
  }

  .sp-gx-landing .gx-about-content {
    max-width: 700px;
    margin-inline: auto;
  }

  .sp-gx-landing .gx-tournament {
    text-align: left;
  }

  .sp-gx-landing .gx-tournament .gx-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
    flex-wrap: wrap;
  }

  .sp-gx-landing .gx-tournament-content,
  .sp-gx-landing .gx-tournament-prize {
    margin-bottom: 0;
  }

  .sp-gx-landing .gx-tournament-content {
    max-width: 310px;
  }

  .sp-gx-landing .gx-tournament .sp-holo-cta {
    margin-inline: 0;
  }

  .sp-gx-landing .gx-tournament-prize,
  .sp-gx-landing .gx-tournament-winners {
    text-align: center;
  }

  .sp-gx-landing .gx-tournament-winners {
    padding: 45px 40px;
    flex: 1;
    min-width: 260px;
  }

  .sp-gx-landing .gx-newsletter {
    padding-bottom: 160px;
  }

  .sp-gx-landing .gx-newsletter-card {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 50px;
    padding: 45px 50px;
  }

  .sp-gx-landing .gx-newsletter-content {
    margin-inline: 0;
    margin-bottom: 0;
  }

  .sp-gx-landing .gx-newsletter-form {
    flex-grow: 1;
    margin-inline: 0;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: stretch;
  }

  .sp-gx-landing .gx-newsletter .gx-input-field {
    flex: 1;
    min-width: 200px;
    margin-bottom: 0;
  }

  .sp-gx-landing .gx-footer-brand-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .sp-gx-landing .gx-footer-top .gx-logo {
    margin-inline: 0;
    margin-bottom: 0;
    margin-right: 50px;
  }

  .sp-gx-landing .gx-footer-menu-wrapper {
    display: flex;
    gap: 50px;
    align-items: center;
    flex: 1;
  }

  .sp-gx-landing .gx-footer-menu-list {
    flex-grow: 1;
    max-width: unset;
  }

  .sp-gx-landing .gx-copyright {
    margin-bottom: 0;
  }
}

/* —— Responsive: 1200px —— */
@media (min-width: 1200px) {
  .sp-gx-landing .gx-container {
    max-width: 1200px;
  }

  .sp-gx-landing .gx-about .gx-container {
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
    align-items: center;
    gap: 80px;
    padding-right: 40px;
  }

  .sp-gx-landing .gx-about-banner {
    margin-inline: 0;
    margin-bottom: 0;
    flex: 0 1 420px;
  }

  .sp-gx-landing .gx-about-content {
    max-width: 600px;
    margin-inline: 0;
  }

  .sp-gx-landing .gx-team-list {
    gap: 20px;
  }

  .sp-gx-landing .gx-gears-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
