/* =========================
   GLOBAL / BASE (mobile first)
========================= */

:root {
  /* ---- Form field tokens ---- */
  --field-h: 48px;
  --field-pt: 16px;
  --field-pb: 6px;
  --field-pl: 5px;
  --field-pr: 44px;

  --underline: 2px;
  --underline-col: rgba(255, 255, 255, 0.35);

  --label-scale: 0.65;
  --label-ty: -0.5rem;
  --label-tx: 0;

  /* brand */
  --blue: #183550;
  --red: #dd061a;
  --yellow: #fcbf00;

  --index-red-start: 298px;
  --index-red-start: 138px;
  --footer-red-start: 299px;
  --footer-red-start: 149px;

  /* wrapper */
  --wrap-max: 1500px;
}

html,
body {
  height: 100%;
}

body {
  background: var(--blue);
  min-height: 100vh;
  color: #fff;
  text-align: center;
  line-height: normal;
  font-family: "foco", sans-serif;
  font-weight: 700;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* =========================================================
   PAGE WRAPPER / DECOR LAYERS (mobile)
========================================================= */

.page-wrapper {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  /* isolation: isolate; */
  container-type: inline-size;
  max-width: 100%;
  margin: 0 auto;
}

/* DECOR LAYER (behind everything) */
.page-decor {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* CONTENT ALWAYS ON TOP */
.page-content {
  position: relative;
  z-index: 2;
}

/* per-page toggle (hide circle) */
.page-wrapper.page--no-circle .circle-shape {
  display: none !important;
}

/* Hide circle on specific pages (your existing logic) */
.c .circle-shape,
.terms .circle-shape,
.faq .circle-shape {
  display: none !important;
}

/* =========================
   MOBILE ICONS (LEFT / RIGHT)
========================= */

.decor-yellow {
  display: none;
}

.page-decor .decor-mob {
  position: absolute;
  height: 980px;
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 1;
}

/* LEFT: top 40→35, width 120→125, left 3→6 */
.page-decor .decor-mob--left {
  right: auto;
  background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/iconsMob_leftV2.webp");
  background-position: left 0;

  top: clamp(35px, calc(40px - (5 * (100vw - 375px) / 55)), 40px);
  width: clamp(120px, calc(120px + (5 * (100vw - 375px) / 55)), 125px);
  left: clamp(3px, calc(3px + (3 * (100vw - 375px) / 55)), 6px);
}

.too-late .page-decor .decor-mob--left {
    right: auto;
    background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/iconsMob_leftVc.webp");
    background-position: left 0;
  
    top: clamp(35px, calc(40px - (5 * (100vw - 375px) / 55)), 40px);
    width: clamp(120px, calc(120px + (5 * (100vw - 375px) / 55)), 125px);
    left: clamp(3px, calc(3px + (3 * (100vw - 375px) / 55)), 6px);
}



/* RIGHT: top 47→44, width 97→100, right -3→7 */
.page-decor .decor-mob--right {
  left: auto;
  background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/iconsMob_rightV2.webp");
  background-position: right 0;

  top: clamp(44px, calc(47px - (3 * (100vw - 375px) / 55)), 47px);
  width: clamp(97px, calc(97px + (3 * (100vw - 375px) / 55)), 100px);
  right: clamp(-3px, calc(-3px + (10 * (100vw - 375px) / 55)), 7px);
}


.too-late .page-decor .decor-mob--right {
  left: auto;
  background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/iconsMob_rightVc.webp");
  background-position: right 0;

  top: clamp(44px, calc(47px - (3 * (100vw - 375px) / 55)), 47px);
  width: clamp(97px, calc(97px + (3 * (100vw - 375px) / 55)), 100px);
  right: clamp(-3px, calc(-3px + (10 * (100vw - 375px) / 55)), 7px);
}

/* per-page toggle (hide mobile icons + padding) */
.page-wrapper.page--no-mob-icons .decor-mob {
  display: none !important;
}

.page-wrapper.page--no-mob-icons .page-content {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* =========================
   HELPERS
========================= */

.fw-900 {
  font-weight: 900 !important;
}

.text-warning {
  color: var(--yellow) !important;
}

.bg-primary {
  background-color: var(--blue) !important;
}

.bg-danger {
  background-color: var(--red) !important;
}

/* =========================
   LOGOS (mobile)
========================= */

.logos {
  width: 200px;
  height: auto;
}

.w-logos {
  width: 88px;
  height: auto;
}

/* =========================
   TYPOGRAPHY (mobile)
========================= */

.big-title,
.lg-title,
.md-title,
.s-title,
.y-title,
.xl-title,
.xxl-title,
.text-form {
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: -0.02em;
}

.xxl-title {
  font-size: 75px;
  line-height: 63px;
}

.xl-title {
  font-size: 60px;
  line-height: 60px;
}

.big-title {
  font-size: 50px;
  line-height: 50px;
}

.lg-title {
  font-size: 38px;
  line-height: 38px;
}

.y-title {
  font-size: 40px;
  line-height: 40px;
  color: var(--yellow);
}

.md-title {
  font-size: 30px;
  line-height: 30px;
}

.s-title {
  font-size: 28px;
  line-height: 28px;
}

.text-form {
  font-size: 22px;
  line-height: 24px;
}

.body-text {
  font-size: 18px;
  line-height: 27px;
  letter-spacing: -0.02em;
  font-weight: 700;
}

/* supers/subs */
sub {
  bottom: -0.1em !important;
}

sup {
  top: -1em;
}

sub,
sup {
  position: relative;
  font-size: 0.4em;
  line-height: normal;
  vertical-align: baseline;
}

.footer-notes {
  font-size: 12px;
  line-height: normal;
}

/* =========================
   BUTTONS (mobile)
========================= */

.magic-btn {
  position: relative;
  width: 250px;
  aspect-ratio: 363 / 109;
  background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/button.svg") no-repeat center / contain;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  border: 0;
  text-decoration: none;
  text-transform: uppercase;
  font-size: 26px;
  font-weight: 900;
  color: #fff;
}

.magic-btn:hover {
  transform: scale(1.04);
  filter: brightness(1.1);
  transition: all 0.2s ease;
  color: #fff;
}

/* =========================
   IMAGES (mobile)
========================= */

.headline {
  width: 100%;
  max-width: 400px;
}

.bisc {
  width: 250px;
  display: block;
  margin: 20px auto;
  transform: translateX(20px);
}

.bisc-static {
  width: 180px;
}

/* =========================
   PACKS (mobile)
========================= */

.pack-wrapper {
  position: relative;
  width: 100%;
  max-width: 520px;
  height: 410px;
  margin: 0 auto;
  overflow: visible;
  pointer-events: none;
  z-index: 2;
}

.pack {
  position: absolute;
  height: auto;
  display: block;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
  will-change: transform;
}

.pack-mini {
  width: 300px;
  left: 50%;
  top: 0;
  z-index: 2;
  transform: translateX(-50%) rotate(0deg);
  transform-origin: 50% 75%;
  animation: miniTilt 9s ease-in-out infinite;
}

.pack-main {
  width: 585px;
  left: 58%;
  top: 193px;
  z-index: 3;
  transform: translateX(-50%) translateY(0px) rotate(0deg);
  transform-origin: 35% 65%;
  animation: mainVortex 9s ease-in-out infinite;
}

.y-badge {
  width: 80px;
  left: 10px;
  top: 108px;
  z-index: 4;
  transform: none;
  will-change: auto;
}

.yellow-starsPack {
  width: 78%;
  left: 50%;
  transform: translateX(-50%);
  top: 379px;
  z-index: 4;
  will-change: auto;
}

/* =========================
   RED BACKGROUNDS (mobile)
========================= */

.red-stage2 {
  position: relative;
  padding-bottom: 0;
  background: transparent;
}

.index .red-stage2::before,
.draw .red-stage2::before {
  content: "";
  position: absolute;
  top: var(--index-red-start);
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: calc(100% - var(--index-red-start));
  background: var(--red);
    z-index: 0;
    pointer-events: none;
  
    box-shadow: 0 0 0 100vmax var(--red);
  
 
    -webkit-mask:
      radial-gradient(ellipse 600px 180px at 50% 0,
        transparent 99%,
        black 100%);
    mask:
      radial-gradient(ellipse 600px 180px at 50% 0,
        transparent 99%,
        black 100%);
  }


.red-stage2>* {
  position: relative;
  z-index: 1;
}

.red-stage {
  position: relative;
}

footer {
  background: transparent;
  box-shadow: none;
  clip-path: none;
}

.red-stage::before {
  content: "";
  position: absolute;
  top: var(--footer-red-start);
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: calc(100% - var(--footer-red-start));
  background: var(--red);
  z-index: 0;
  pointer-events: none;

  box-shadow: 0 0 0 100vmax var(--red);

  -webkit-mask:
    radial-gradient(ellipse 600px 180px at 50% 0,
      transparent 99%,
      black 100%);
  mask:
    radial-gradient(ellipse 600px 180px at 50% 0,
      transparent 99%,
      black 100%);
}

.navSpace{
  margin-top: -10px;
}

.red-stage>* {
  position: relative;
  z-index: 1;
}

.packs-bottom {
  position: relative;
  z-index: 2;
}

.red-stage sup {
  top: -5px;
}

.red-stage sub,
.red-stage sup {
  position: relative;
  font-size: 14px;
  line-height: normal;
  vertical-align: baseline;
}

/* claim page mobile yellow decor */
.c .decor-yellow {
  display: block;
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/claim-icons-yellowMob3.webp");
  background-repeat: no-repeat;
  background-position: 50% 0%;
  background-size: 100%;
  height: 1230px;
  top: 28px;
}

/* =========================
   FORM (mobile)
========================= */

.form-stage {
  padding: 0 5px 60px;
}

.form-shape {
  position: relative;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: 88px 22px 60px;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  z-index: 1;
  display: flow-root;
}

.form-shape::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/form-bgMob.webp") no-repeat center / 100% 100%;
  pointer-events: none;
  z-index: -1;
}

.form-shape .row {
  margin-left: 0;
  margin-right: 0;
}

.form-shape>form {
  max-width: 520px;
  margin: 0 auto;
}

/* =========================
   FORM SYSTEM (inputs/selects)
========================= */

.form-control,
.form-select {
  background: transparent !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  border-bottom: var(--underline) solid var(--underline-col) !important;
  background-image: none !important;
  background-repeat: no-repeat !important;
}

.form-control:focus,
.form-select:focus {
  background: transparent !important;
  color: #fff !important;
  border: 0 !important;
  box-shadow: none !important;
  border-bottom: var(--underline) solid var(--underline-col) !important;
  background-image: none !important;
}

.form-floating>.form-control,
.form-floating>.form-select,
.form-floating>.form-control-plaintext {
  height: var(--field-h) !important;
  min-height: var(--field-h) !important;
  padding: var(--field-pt) var(--field-pr) var(--field-pb) var(--field-pl) !important;
  line-height: 1.2 !important;
  font-size: 18px;
  font-weight: 900;
}

.form-floating>.form-select {
  padding-right: var(--field-pr) !important;
  -webkit-appearance: none;
  appearance: none;
}

.form-floating>label {
  padding: 1rem 0.2rem;
  top: -8px;
}

.form-floating>.form-control-plaintext~label,
.form-floating>.form-control:focus~label,
.form-floating>.form-control:not(:placeholder-shown)~label {
  opacity: 0.65;
  transform: scale(var(--label-scale)) translateY(var(--label-ty)) translateX(var(--label-tx));
}

.form-select option[value=""] {
  display: none;
}

.form-floating.floating-select>label {
  opacity: 1;
  transform: none;
  top: 0;
}

.form-floating.floating-select>.form-select:focus~label,
.form-floating.floating-select>.form-select:required:valid~label {
  opacity: 0.65;
  transform: scale(var(--label-scale)) translateY(var(--label-ty)) translateX(var(--label-tx));
  top: -8px;
}

.form-floating.floating-select {
  position: relative;
}

.form-floating.floating-select::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 50%;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px 16px;
  pointer-events: none;
  opacity: 0.9;
}

.form-control.is-valid,
.was-validated .form-control:valid,
.form-control.is-valid:focus,
.was-validated .form-control:valid:focus,
.form-select.is-valid,
.was-validated .form-select:valid,
.form-select.is-valid:focus,
.was-validated .form-select:valid:focus {
  border: 0 !important;
  border-bottom: var(--underline) solid var(--underline-col) !important;
  box-shadow: none !important;
  padding-right: var(--field-pr) !important;
  background-image: none !important;
}

.form-control.is-valid,
.was-validated .form-control:valid,
.form-control.is-valid:focus,
.was-validated .form-control:valid:focus {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23ffffff' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 1rem 1rem !important;
}

.form-select.is-invalid:not([multiple]):not([size]),
.form-select.is-invalid:not([multiple])[size="1"],
.was-validated .form-select:invalid:not([multiple]):not([size]),
.was-validated .form-select:invalid:not([multiple])[size="1"] {
  padding-right: var(--field-pr) !important;
  background-image: none !important;
}

.invalid-feedback {
  display: none;
  width: 100%;
  margin-top: 0.25rem;
  font-size: 16px;
  color: #dc3545;
  text-align: left;
  border: none;
  text-transform: math-auto;
}

.form-check-input {
  border: 4px solid var(--red);
  background-color: var(--red);
  border-radius: 50% !important;
  width: 22px;
  height: 22px;
}

.form-check-input:checked {
  background-color: #193650;
  border-color: var(--red);
  border: 4px solid var(--red);
}

.form-check-input.is-invalid,
.was-validated .form-check-input:invalid {
  border-color: #ffffff;
}

.form-check-input.is-valid~.form-check-label,
.was-validated .form-check-input:valid~.form-check-label {
  color: #ffffff;
}

.form-check-input.is-valid,
.was-validated .form-check-input:valid {
  border-color: #dd071a;
}

.form-check-input.is-valid:checked,
.was-validated .form-check-input:valid:checked {
  background-color: transparent;
}

.form-check-label {
  text-transform: none;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill,
select:-webkit-autofill {
  -webkit-text-fill-color: #fff !important;
  transition: background-color 9999s ease-in-out 0s;
  box-shadow: 0 0 0px 1000px transparent inset !important;

}

/* =========================
   FOOTER (mobile)
========================= */

.social-icon {
  width: auto;
  height: 30px;
}

.footer-link {
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: 0.01em;
  font-size: 20px;
  line-height: 1;
  color: #fff;
}

.footer-link:hover {
  text-decoration: underline;
  text-underline-offset: 4px;
}

.footer-stage {
  position: relative;
  overflow: hidden;
}

ol ol,
ol ul,
ul ol,
ul ul {
  margin-bottom: 0;
  padding-left: 13px;
}

/* page-specific */
.index .packs-bottom,
.draw .packs-bottom {
  display: none;
}

.index footer,
.draw footer {
  background-color: #dd061a;
}

.extra-stars {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -130px;
  height: 180px;
  pointer-events: none;
  background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/bottom-icons-yellowMob.webp") no-repeat top center / contain;
}

.c .extra-stars {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 119px;
  height: 180px;
  pointer-events: none;
  background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/bottom-icons-yellowMob.webp") no-repeat top center / contain;
}

/* Stars layer (hidden by default) */
.footer-decor--stars {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 240px;
  pointer-events: none;
  background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/bottom-icons-yellowMob.webp") no-repeat top center / contain;
  display: none;
}

.c .packs-bottom,
.terms .packs-bottom,
.faq .packs-bottom {
  display: none;
}

.c .decor-mob {
  display: none;
}

.terms .decor-mob,
.terms .decor-yellow,
.faq .decor-mob,
.faq .decor-yellow {
  display: none;
}

body.c {
  background-color: var(--red) !important;
}

.terms .page-wrapper,
.faq .page-wrapper {
  background-color: var(--blue) !important;
}



/* =========================
   PACK ANIMATIONS
========================= */

@keyframes miniTilt {
  0% {
    transform: translateX(-50%) rotate(0deg);
  }

  8% {
    transform: translateX(-50%) rotate(-1.4deg);
  }

  16% {
    transform: translateX(-50%) rotate(1.2deg);
  }

  24% {
    transform: translateX(-50%) rotate(-0.8deg);
  }

  32% {
    transform: translateX(-50%) rotate(0deg);
  }

  100% {
    transform: translateX(-50%) rotate(0deg);
  }
}

@keyframes mainVortex {

  0%,
  34% {
    transform: translateX(-50%) translateY(0px) rotate(0deg);
  }

  44% {
    transform: translateX(calc(-50% + 6px)) translateY(-4px) rotate(2deg);
  }

  52% {
    transform: translateX(calc(-50% - 5px)) translateY(2px) rotate(-1.6deg);
  }

  60% {
    transform: translateX(calc(-50% + 2px)) translateY(-1px) rotate(0.8deg);
  }

  70% {
    transform: translateX(-50%) translateY(0px) rotate(0deg);
  }

  100% {
    transform: translateX(-50%) translateY(0px) rotate(0deg);
  }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {

  .pack-mini,
  .pack-main {
    animation: none !important;
  }
}

/* =========================================================
   BREAKPOINTS (in order)
========================================================= */

/* 400px */
/* @media (min-width: 400px) {
  :root {
    --mob-icons-gap: clamp(-10px, calc(38.4615vw - 163.846px), 0px);
  }
} */

/* 426px */
/* @media (min-width: 426px) {
  :root {
    --mob-icons-gap: 0px;
  }
} */

/* 626px */

@media (min-width: 570px) {
    .page-decor .decor-mob--right {
      top: 10px;
      width: 122px;
      right: 30px;
      left: auto;
      /* keep reset */
    }

    .page-decor .decor-mob--left {
      top: 15px;
      width: 175px;
      left: 40px;
      right: auto;
      /* keep reset */
    }
  }


/* 768px */
@media (min-width: 768px) {
  .logos {
    width: 426px;
  }

  .pack-wrapper {
    max-width: 720px;
    height: 512px;
  }

  .pack-mini {
    width: 300px;
    left: 46%;
  }

  .pack-main {
    width: 585px;
    left: 50%;
  }

  .y-badge {
    width: 80px;
    left: 140px;
  }

  .yellow-starsPack {
    width: 58%;
    left: 50%;
    transform: translateX(-50%);
    top: 393px;
  }
}

/* 992px */
@media (min-width: 992px) {
  body {
    background: var(--red);
  }

  .page-wrapper {
    max-width: var(--wrap-max);
    background: var(--red);
    /* box-shadow: 0 20px 60px rgba(0, 0, 0, .25),
      0 5px 20px rgba(0, 0, 0, .15); */
  }

  .page-content {
    padding-left: 0;
    padding-right: 0;
  }

  .decor-mob {
    display: none;
  }

  .decor-yellow {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/icons-yellow.webp");
    background-repeat: no-repeat;
    background-position: 50% 0%;
    background-size: clamp(1100px, calc(57.565vw + 529px), 1450px);
  }

  .page-wrapper.page--no-yellow .decor-yellow {
    display: none !important;
  }

  /* circle */
  .circle-shape {
    position: absolute;
    right: 0;
    top: clamp(-118px, calc(-8.6538vw - 14.1538px), -100px);
    width: 1350px;
    aspect-ratio: 1433 / 1135;
    z-index: 1;
    pointer-events: none;
    background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/shape.webp") no-repeat top right / contain;
  }

  .circle-shape .circle-icons {
    position: absolute;
    --gx: clamp(95px, calc(-46.875vw + 844.75px), 380px);
    --gy: clamp(104px, calc(-15.789vw + 356.63px), 200px);
    left: var(--gx);
    top: var(--gy);
    display: flex;
    align-items: flex-start;
    --g: clamp(159px, calc(-6.743vw + 266.89px), 200px);
    gap: var(--g);
    transform-origin: top left;
    transform: none;
    pointer-events: none;
  }

  .circle-shape .circle-icon {
    display: block;
    height: auto;
    max-width: none;
    pointer-events: none;
    user-select: none;
  }

  .circle-shape .circle-icon--left {
    width: clamp(300px, calc(21.382vw + 87.96px), 430px);
  }

  .circle-shape .circle-icon--right {
    width: clamp(460px, calc(18.0921vw + 280.5263px), 570px);
    margin-top: 39px;
  }

  /* logos */
  .logos {
    width: 526px;
  }

  .w-logos {
    position: absolute;
    top: 52px;
    right: 19px;
  }

  /* typography desktop */
  .xxl-title {
    font-size: 100px;
    line-height: 83px;
  }

  .xl-title {
    font-size: 70px;
    line-height: 70px;
  }

  .big-title {
    font-size: 63px;
    line-height: 63px;
  }

  .lg-title {
    font-size: 50px;
    line-height: 50px;
  }

  .s-title {
    font-size: 35px;
    line-height: 35px;
  }

  .body-text {
    font-size: 20px;
    line-height: 27px;
  }

  .footer-notes {
    font-size: 16px;
  }

  /* button desktop */
  .magic-btn {
    width: 320px;
  }

  /* packs desktop */
  .pack-wrapper {
    max-width: 720px;
    height: 512px;
  }

  .pack-main {
    width: 634px;
    left: 50%;
    top: 218px;
  }

  .pack-mini {
    width: 342px;
    left: 50%;
    top: 0;
  }

  .y-badge {
    width: 90px;
    left: 172px;
    top: 160px;
  }

  .pack-wrapper {
    max-width: 720px;
    height: 512px;
    height: 477px;
  }

  .stars-wrapper {
    position: relative;
    width: 100%;
    max-width: 2000px;
    margin: 0 auto;
    background: 
    url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/wr-startsL.webp") no-repeat, 
    url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/wr-startsL.webp") no-repeat;
    background-position: 20px 0px, 100% 0px;
      background-size: 180px auto, 180px auto;
      overflow: visible;
      background-repeat: repeat-y;
  }


  .stars-wrapper>.page-wrapper {
    position: relative;
    max-width: var(--wrap-max);
    margin: 0 auto;
  }

  .stars-wrapper>.page-wrapper {
    pointer-events: auto;
  }

  /* Desktop: disable mobile red pseudo blocks */
  .index .red-stage2::before,
  .draw .red-stage2::before,
  .red-stage::before {
    display: none;
  }

  footer {
    background: none;
    box-shadow: none;
    clip-path: none;
  }

  /* index/draw desktop yellow decor overrides */
  .index .decor-yellow,
  .draw .decor-yellow {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/form-icons-yellow2.webp");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
  }

  .c .decor-yellow {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/claim-icons-yellow.webp");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: contain;
  }

  /* footer stars desktop */
  .footer-stage {
    padding-top: 0;
  }

  .footer-decor--stars {
    height: 240px;
    background-image: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/bottom-icons-yellow.webp");
  }

  .index .footer-decor--stars,
  .draw .footer-decor--stars {
    display: block;
  }

  /* form desktop */
  .form-stage {
    padding: 0 0 60px;
  }

  .form-shape {
    max-width: 820px;
    padding: 88px 158px 60px;
  }

  .form-shape::before {
    background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/form-bg.svg") no-repeat center / 100% 100%;
  }

  .form-shape.form-shapeCl::before {
    background: url("https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/form-Clbg.svg") no-repeat center / 100% 100%;
  }

  .form-shape>form {
    max-width: 560px;
  }

  .decor-yellow {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    background-image: url(https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/icons-yellow.webp);
    background-repeat: no-repeat;
    background-position: 50% 0%;
    background-size: clamp(1100px, calc(57.565vw + 529px), 1450px);
    background-position: -21px 0;
  }
}

/* 1100px */
@media (min-width: 1100px) {
  .form-shape {
    padding: 88px 168px 60px;
  }
}

/* 1200px */
@media (min-width: 1200px) {
  .circle-shape {
    top: clamp(-118px, calc(7vw - 202px), -90px);
  }

  .circle-shape .circle-icons {
    --gx: clamp(95px, calc(-32.5vw + 615px), 225px);
  }
}

/* 1600px */
@media (min-width: 1550px) {
  .circle-shape {
    top: -90px;
  }
}

@media (min-width: 1550px) {
  .stars-wrapper>.page-wrapper {
    position: relative;
    max-width: 1800px;
    margin: 0 auto;
  }

  .circle-shape {
    top: -236px;
    top: -206px;
    width: 1510px;
    aspect-ratio: 1533 / 1215;
  }

  .circle-shape .circle-icons {
    position: absolute;
    --gx: clamp(95px, calc(-46.875vw + 844.75px), 380px);
    --gy: clamp(104px, calc(-15.789vw + 356.63px), 200px);
    left: 50px;
    top: var(--gy);
    display: flex;
    align-items: flex-start;
    --g: 259px;
    --g: 329px;
    gap: var(--g);
    transform-origin: top left;
    transform: none;
    pointer-events: none;
  }


  .index .decor-yellow,
  .draw .decor-yellow {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background-image: url(https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/form-icons-yellow2.webp);
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 87%;
  }

    .decor-yellow {
      display: block;
      position: absolute;
      inset: 0;
      z-index: 0;
      background-image: url(https://umb-4553t5.s3.eu-west-1.amazonaws.com/8712/media/icons-yellow.webp);
      background-repeat: no-repeat;
      background-position: 50% 0%;
      background-size: 89%;
      background-position: top center;
    }

}



/* =========================
   MODALS 
========================= */

.modal-content {
  background-color: var(--blue);
}

.limit-modal .modal-backdrop.show,
.modal-backdrop.show {
  background: var(--red);
  opacity: 0.9;
}

.limit-modal .modal-dialog {
  width: min(520px, 92vw);
  margin-inline: auto;
}

.limit-card {
  position: relative;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}

.limit-shape {
  width: 100%;
  height: auto;
  display: block;
}

.limit-inner {
  position: absolute;
  inset: clamp(70px, 10vw, 110px) clamp(28px, 6vw, 54px) clamp(60px, 10vw, 90px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
}

.limit-close {
  position: absolute;
  top: clamp(20px, 4vw, 40px);
  right: clamp(20px, 4vw, 40px);
  z-index: 2;
  filter: invert(1);
  opacity: 1;
}

.btn-close {
  filter: invert(1);
}

.modal {
  z-index: 2000 !important;
}

.modal-backdrop {
  z-index: 1990 !important;
}

