/*
Theme Name: WC2026 Chuyển Sân
Theme URI: https://example.com/wc2026chuyensan
Author: Your Name
Author URI: https://example.com
Description: WordPress theme chuyển đổi từ WorldCup2026 Landing Page - Responsive, hỗ trợ Mobile & Desktop. Giao diện World Cup 2026 với form đăng ký nhận ưu đãi chuyển sân.
Version: 1.0.0
Requires at least: 5.0
Tested up to: 6.4
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wc2026chuyensan
*/

:root {
  --navy-950: #02082b;
  --navy-900: #041144;
  --navy-800: #061b5d;
  --blue-600: #0068ff;
  --cyan-400: #00c8ff;
  --lime-400: #8fe600;
  --red-500: #ff2b16;
  --gold-400: #ffd43b;
  --gold-500: #ffb800;
  --white: #ffffff;
  --shadow-blue: rgba(0, 119, 255, .55);
  --shadow-red: rgba(255, 55, 25, .45);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; min-height: 100%; }
body {
  min-height: 100vh;
  color: var(--white);
  background: #010516;
  font-family: "Be Vietnam Pro", "Montserrat", Arial, sans-serif;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body.no-scroll { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
.mobile-only, .desktop-only { display: none; width: 100%; min-height: 100dvh; }
@media (max-width: 767.98px) {
  body { background: #01030f; }
  .mobile-only { display: block; }
  .desktop-only { display: none !important; }
}
@media (min-width: 768px) {
  body { background: var(--navy-950); }
  .desktop-only { display: block; }
  .mobile-only { display: none !important; }
}

.shared-pop {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(0, 4, 18, .8);
  backdrop-filter: blur(6px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s ease;
}
.shared-pop.on { opacity: 1; pointer-events: auto; }
.shared-pop__box {
  position: relative;
  width: min(420px, 100%);
  padding: 40px 30px;
  text-align: center;
  border: 2px solid transparent;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(7, 24, 74, .96) 0%, rgba(3, 13, 48, .96) 100%) padding-box,
    linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
  box-shadow: 0 0 26px var(--shadow-blue), 0 0 30px var(--shadow-red), 0 26px 60px rgba(0, 0, 0, .5);
  transform: scale(.86) translateY(22px);
  transition: transform .34s cubic-bezier(.34, 1.56, .64, 1);
}
.shared-pop.on .shared-pop__box { transform: scale(1) translateY(0); }
.shared-pop__icon { display: block; font-size: 58px; margin-bottom: 12px; }
.shared-pop__title {
  margin: 0 0 12px;
  color: var(--gold-400);
  text-transform: uppercase;
  font-size: clamp(25px, 6vw, 30px);
  font-weight: 900;
  letter-spacing: .4px;
  line-height: 1.05;
}
.shared-pop__msg {
  margin: 0 0 26px;
  color: #fff;
  font-size: clamp(16px, 4.2vw, 18px);
  font-weight: 600;
  line-height: 1.5;
}
.shared-pop__btn {
  min-width: 180px;
  height: 56px;
  padding: 0 40px;
  border: 0;
  border-radius: 14px;
  cursor: pointer;
  color: #092b76;
  text-transform: uppercase;
  font-size: 22px;
  font-weight: 900;
  letter-spacing: .5px;
  background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
  box-shadow: inset 0 2px 0 rgba(255, 255, 255, .55), inset 0 -5px 0 rgba(177, 91, 0, .36), 0 12px 28px rgba(255, 168, 0, .34);
  transition: transform .18s ease, filter .18s ease;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.shared-pop__btn::after {
  content: "";
  position: absolute;
  top: -20%; left: -75%;
  width: 45%; height: 140%;
  background: linear-gradient(100deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.15) 38%, rgba(255,255,255,.85) 50%, rgba(255,255,255,.15) 62%, rgba(255,255,255,0) 100%);
  transform: skewX(-22deg);
  pointer-events: none;
  z-index: 2;
  animation: sharedBtnShine 2.8s ease-in-out infinite;
}
.shared-pop__btn:active { transform: translateY(1px); }
@keyframes sharedBtnShine {
  0% { left: -75%; }
  55% { left: 130%; }
  100% { left: 130%; }
}
@media (prefers-reduced-motion: reduce) {
  .shared-pop, .shared-pop__box, .shared-pop__btn::after { transition: none; animation: none; }
}

:root {--navy-950: #02082b;
      --navy-900: #041144;
      --navy-800: #061b5d;
      --blue-600: #0068ff;
      --cyan-400: #00c8ff;
      --lime-400: #8fe600;
      --red-500: #ff2b16;
      --orange-500: #ff9e00;
      --gold-400: #ffd43b;
      --gold-500: #ffb800;
      --white: #ffffff;
      --muted: rgba(255, 255, 255, .72);
      --shadow-blue: rgba(0, 119, 255, .55);
      --shadow-red: rgba(255, 55, 25, .45);
      --shell: 480px;}
* {box-sizing: border-box;}
html {scroll-behavior: smooth;}
.mobile-only {margin: 0;
      background: #01030f;
      color: var(--white);
      font-family: "Be Vietnam Pro", "Montserrat", "Arial", sans-serif;
      -webkit-font-smoothing: antialiased;}
.mobile-only a {color: inherit; text-decoration: none;}
.mobile-only button, .mobile-only input {font: inherit;}
.mobile-only .sr-only {position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
      overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;}

.mobile-only .shell {position: relative;
      width: 100%;
      max-width: var(--shell);
      margin: 0 auto;
      background: var(--navy-950);
      min-height: 100vh;
      overflow: hidden;
      box-shadow: 0 0 80px rgba(0, 0, 0, .6);}

.mobile-only .hero {position: relative;
      isolation: isolate;
      min-height: 100dvh;
      height: auto;
      overflow: visible;
      display: flex;
      flex-direction: column;
      background: var(--navy-950);}
.mobile-only .hero__art {position: relative;
      display: block;
      width: 100%;
      height: clamp(248px, 38vh, 480px);
      flex: 0 0 auto;
      object-fit: cover;
      object-position: top center;}

.mobile-only .hero::after {content: "";
      position: absolute;
      left: 0; right: 0; top: clamp(200px, 31vh, 420px);
      height: clamp(60px, 9vh, 120px);
      z-index: 1;
      pointer-events: none;
      background: linear-gradient(180deg, rgba(2, 8, 43, 0) 0%, rgba(2, 8, 43, .45) 42%, rgba(2, 8, 43, .82) 72%, var(--navy-950) 100%);}

.mobile-only .form-section {position: relative;
      left: auto; right: auto; top: auto;
      margin-top: calc(-1 * clamp(44px, 8vh, 96px));
      flex: 1 1 auto;
      z-index: 2;
      padding: 0 14px max(14px, env(safe-area-inset-bottom));
      background: linear-gradient(180deg,
        rgba(2, 8, 43, 0) 0%,
        rgba(2, 8, 43, .35) 14%,
        rgba(2, 8, 43, .72) 30%,
        var(--navy-950) 46%);}
.mobile-only .form-card {position: relative;
      width: 100%;
      padding: 13px 18px 13px;
      border: 2px solid transparent;
      border-radius: 24px;
      background:
        linear-gradient(180deg, rgba(7, 24, 74, .94) 0%, rgba(3, 13, 48, .96) 100%) padding-box,
        linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
      box-shadow:
        0 0 22px var(--shadow-blue),
        0 0 26px var(--shadow-red),
        inset 0 0 34px rgba(0, 124, 255, .2),
        0 26px 60px rgba(0, 0, 0, .42);}
.mobile-only .form-title-wrap {text-align: center; margin-bottom: 5px;}
.mobile-only .form-title {position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 40px;
      padding: 4px 32px;
      color: #0c2d78;
      background: linear-gradient(180deg, #ffffff 0%, #f6f8ff 52%, #eef2ff 100%);
      border: 3px solid #ff8a0a;
      clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
      text-transform: uppercase;
      white-space: nowrap;
      font-size: 26px;
      font-weight: 900;
      line-height: 1;
      letter-spacing: -.8px;
      text-shadow: 0 2px 0 #ffffff, 0 4px 0 rgba(0, 36, 105, .12);
      box-shadow: 0 8px 20px rgba(0, 0, 0, .22);}
.mobile-only .form-subtitle {margin: 0 0 9px;
      color: rgba(255, 255, 255, .9);
      text-align: center;
      font-size: 12.5px;
      font-weight: 600;
      line-height: 1.3;}
.mobile-only .field-group {display: grid; gap: 4px; margin-bottom: 7px;}
.mobile-only .field-label {display: flex; align-items: center; gap: 10px;
      color: #fff; font-size: 13.5px; font-weight: 800;}
.mobile-only .step-number {display: inline-flex; align-items: center; justify-content: center;
      width: 25px; height: 25px; flex: 0 0 25px;
      border-radius: 8px;
      color: #09245e; font-size: 17px; font-weight: 900;
      background: linear-gradient(180deg, #ffe855 0%, #ffc400 100%);
      box-shadow: inset 0 -3px 0 rgba(180, 95, 0, .32);}
.mobile-only .input-control {width: 100%; height: 38px;
      border: 1.5px solid rgba(255, 255, 255, .34);
      border-radius: 10px;
      outline: none;
      color: #fff;
      background: rgba(5, 15, 52, .74);
      padding: 0 15px;
      font-size: 14px; font-weight: 600;
      transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;}
.mobile-only .input-control::placeholder {color: rgba(255, 255, 255, .46);}

.mobile-only .amount-toggle {display: grid; grid-template-columns: 1fr 1fr; gap: 6px;}
.mobile-only .amt-opt {position: relative; cursor: pointer;}
.mobile-only .amt-opt input {position: absolute; opacity: 0; width: 0; height: 0; margin: 0;}
.mobile-only .amt-opt span {display: flex; align-items: center; justify-content: center; gap: 10px;
      height: 44px; padding: 0 10px;
      border-radius: 12px;
      border: 1.5px solid rgba(255, 255, 255, .28);
      background: rgba(5, 15, 52, .6);
      color: rgba(255, 255, 255, .9);
      font-size: 15px; font-weight: 700; text-align: center;
      transition: border-color .18s ease, background-color .18s ease, color .18s ease, box-shadow .18s ease;}

.mobile-only .amt-opt span::before {content: "";
      flex: 0 0 20px; width: 20px; height: 20px;
      border-radius: 50%;
      border: 2.5px solid rgba(255, 255, 255, .65);
      background: transparent;
      transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;}
.mobile-only .amt-opt input:checked + span {border-color: var(--gold-400);
      background: linear-gradient(180deg, rgba(255, 212, 59, .22), rgba(255, 184, 0, .12));
      color: #fff;
      box-shadow: inset 0 0 16px rgba(255, 184, 0, .22), 0 0 14px rgba(255, 184, 0, .26);}
.mobile-only .amt-opt input:checked + span::before {border-color: var(--gold-400);
      background:
        radial-gradient(circle at 50% 50%, var(--gold-400) 0 42%, transparent 48%);
      box-shadow: 0 0 12px rgba(255, 212, 59, .6);}
.mobile-only .amt-opt input:focus-visible + span {outline: 2px solid var(--cyan-400); outline-offset: 2px;}
.mobile-only .input-control:focus {border-color: rgba(0, 200, 255, .9);
      background: rgba(7, 24, 74, .86);
      box-shadow: 0 0 0 4px rgba(0, 200, 255, .12), 0 0 18px rgba(0, 200, 255, .18);}
.mobile-only .confirm-row {display: flex; align-items: flex-start; gap: 10px;
      margin: 8px 0 10px;
      color: rgba(255, 255, 255, .95);
      font-size: 12.5px; font-weight: 600; line-height: 1.3;
      cursor: pointer;}
.mobile-only .confirm-row input {appearance: none; -webkit-appearance: none;
      width: 24px; height: 24px; margin: 0; flex: 0 0 24px;
      border: 3px solid rgba(255, 255, 255, .85);
      border-radius: 8px;
      background: rgba(255, 255, 255, .03);
      cursor: pointer;
      transition: background-color .2s ease, box-shadow .2s ease, border-color .2s ease;}
.mobile-only .confirm-row input:checked {border-color: var(--gold-400);
      background:
        linear-gradient(135deg, transparent 0 42%, #092b76 42% 57%, transparent 57%),
        linear-gradient(45deg, transparent 0 52%, #092b76 52% 67%, transparent 67%),
        var(--gold-400);
      box-shadow: 0 0 16px rgba(255, 212, 59, .46);}
.mobile-only .submit-btn {width: 100%; height: 48px;
      border: 0; border-radius: 13px; cursor: pointer;
      color: #092b76;
      text-transform: uppercase;
      font-size: 24px; font-weight: 900; letter-spacing: .5px;
      background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
      box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, .55),
        inset 0 -5px 0 rgba(177, 91, 0, .36),
        0 12px 28px rgba(255, 168, 0, .34);
      transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;}
.mobile-only .submit-btn:active {transform: translateY(1px) scale(.995);}

.mobile-only .submit-btn, .mobile-only .sticky-cta__btn, .mobile-only .pcls {position: relative;
      overflow: hidden;
      isolation: isolate;}
.mobile-only .submit-btn::after, .mobile-only .sticky-cta__btn::after, .mobile-only .pcls::after {content: "";
      position: absolute;
      top: -20%; left: -75%;
      width: 45%; height: 140%;
      background: linear-gradient(100deg, rgba(255,255,255,0) 0%, rgba(255,255,255,.15) 38%, rgba(255,255,255,.85) 50%, rgba(255,255,255,.15) 62%, rgba(255,255,255,0) 100%);
      transform: skewX(-22deg);
      pointer-events: none;
      z-index: 2;
      animation: btnShine 3.4s ease-in-out infinite;}
.mobile-only .sticky-cta__btn::after {animation-duration: 3s;}
.mobile-only .pcls::after {animation-duration: 2.8s;}
@keyframes btnShine {0%   { left: -75%; }
      55%  { left: 130%; }
      100% { left: 130%; }}
@media (prefers-reduced-motion: reduce) {.mobile-only .submit-btn::after, .mobile-only .sticky-cta__btn::after, .mobile-only .pcls::after {animation: none; opacity: 0;}}
.mobile-only .secure-note {display: flex; align-items: center; justify-content: center; gap: 7px;
      margin-top: 8px;
      color: rgba(255, 255, 255, .58);
      font-size: 11px; font-weight: 600; text-align: center; line-height: 1.3;}

.mobile-only .section {position: relative;
      overflow: hidden;
      padding: 54px 16px;}

.mobile-only .section--offer {min-height: 100svh;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 12px;
      padding: 26px 16px;

      background:
        radial-gradient(135% 58% at 50% 52%, rgba(0, 110, 255, .32), transparent 64%),
        radial-gradient(120% 60% at 88% 96%, rgba(255, 43, 22, .10), transparent 55%),
        linear-gradient(180deg, #02082b 0%, #02082b 13%, #061f5b 46%, #051a55 70%, #030f3a 88%, #02082b 100%);}
.mobile-only .offer-head {text-align: center;}
.mobile-only .sec-head {position: relative; text-align: center; margin: 0 auto 32px;}
.mobile-only .sec-head {position: relative; text-align: center; margin: 0 auto;}
.mobile-only .sec-title {margin: 0; color: #fff;
      font-size: 23px; font-weight: 900; line-height: 1.12;
      text-transform: uppercase; text-wrap: balance;
      text-shadow: 0 4px 0 rgba(0, 0, 0, .25);}
.mobile-only .sec-title b {color: var(--gold-400);}

.mobile-only .sec-title--banner {display: block; width: 100%;
      padding: 4px 0;
      background: none;
      border: 0;
      box-shadow: none;
      font-size: 22px; line-height: 1.05;}

.mobile-only .podium-card {position: relative;
      width: 100%;
      max-width: 344px;
      margin: 0 auto;
      padding: 0;
      filter: drop-shadow(0 22px 36px rgba(0, 0, 0, .55)) drop-shadow(0 0 28px rgba(0, 140, 255, .3));}
.mobile-only .podium-card__img {display: block; width: 100%; height: auto;}

.mobile-only .steps-rail {position: relative;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      align-items: start;}
.mobile-only .steps-rail .step:nth-child(3) {grid-column: 1 / -1;
      width: 54%;
      max-width: 204px;
      justify-self: center;}
.mobile-only .step {position: relative; text-align: center;
      padding: 17px 10px 12px;
      border-radius: 14px;
      background: linear-gradient(180deg, rgba(12, 40, 110, .5) 0%, rgba(5, 16, 56, .5) 100%);
      border: 1px solid rgba(0, 170, 255, .34);
      box-shadow: inset 0 0 26px rgba(0, 120, 255, .12), 0 16px 34px rgba(0, 0, 0, .34);
      opacity: 0; transform: translateY(28px);}
.mobile-only .steps-rail.lit .step {animation: stepIn .6s cubic-bezier(.34,1.56,.64,1) forwards;}
.mobile-only .steps-rail.lit .step:nth-child(1) {animation-delay: .12s;}
.mobile-only .steps-rail.lit .step:nth-child(2) {animation-delay: .30s;}
.mobile-only .steps-rail.lit .step:nth-child(3) {animation-delay: .50s;}
@keyframes stepIn {to { opacity: 1; transform: translateY(0); }}

.mobile-only .step {transition: border-color .45s ease, box-shadow .45s ease, background .45s ease;}
.mobile-only .step__node {transition: border-color .45s ease, box-shadow .45s ease, transform .45s ease;}
.mobile-only .step.is-active {border-color: rgba(255, 212, 59, .7);
      background: linear-gradient(180deg, rgba(18, 56, 140, .72) 0%, rgba(8, 22, 70, .72) 100%);
      box-shadow: inset 0 0 30px rgba(0, 150, 255, .22), 0 0 28px rgba(255, 184, 0, .4), 0 18px 36px rgba(0, 0, 0, .42);}
.mobile-only .step.is-active .step__node {border-color: rgba(130, 230, 255, .95);
      box-shadow: 0 0 36px rgba(0, 200, 255, .9), inset 0 0 22px rgba(0, 200, 255, .55);
      transform: scale(1.1);}
.mobile-only .step.is-active .step__no {box-shadow: 0 0 16px rgba(255, 200, 0, .85), 0 5px 12px rgba(0, 0, 0, .45);}
@media (prefers-reduced-motion: reduce) {.mobile-only .step {opacity: 1; transform: none;}}
.mobile-only .step__node {position: relative; z-index: 1;
      width: 44px; height: 44px; margin: 0 auto 8px;
      border-radius: 14px;
      display: grid; place-items: center; color: #8fe0ff;
      background: linear-gradient(160deg, #0c3aa0, #061b5d);
      border: 2px solid rgba(0, 200, 255, .55);
      box-shadow: 0 0 22px rgba(0, 140, 255, .45), inset 0 0 16px rgba(0, 150, 255, .3);}
.mobile-only .step__node svg {width: 20px; height: 20px;}
.mobile-only .step__no {position: absolute; top: -8px; right: -8px;
      width: 22px; height: 22px; border-radius: 50%;
      display: grid; place-items: center;
      color: #09245e; font-weight: 900; font-size: 11.5px;
      background: linear-gradient(180deg, #ffe855, #ffc400);
      box-shadow: 0 5px 12px rgba(0, 0, 0, .45);}
.mobile-only .step__title {margin: 0 0 4px; color: #fff; font-weight: 800;
      font-size: 11.5px; text-transform: uppercase; letter-spacing: .01em;
      text-wrap: balance;}
.mobile-only .step__desc {margin: 0 auto; max-width: 280px;
      color: var(--muted); font-size: 10px; line-height: 1.45; font-weight: 500;
      text-wrap: pretty;}

.mobile-only .foot {padding: 26px 16px calc(96px + env(safe-area-inset-bottom));
      background: #01051d;
      border-top: 1px solid rgba(255, 255, 255, .1);
      color: rgba(255, 255, 255, .6);
      font-size: 13px;}
.mobile-only .foot__in {display: flex; flex-direction: column; gap: 14px;
      align-items: center; text-align: center;}
.mobile-only .foot__links {display: flex; gap: 18px; flex-wrap: wrap; justify-content: center;}
.mobile-only .foot a:hover {color: var(--gold-400);}

.mobile-only .sticky-cta {position: fixed;
      left: 50%;
      transform: translateX(-50%);
      bottom: 0;
      z-index: 60;
      width: 100%;
      max-width: var(--shell);
      padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
      background: linear-gradient(180deg, rgba(2, 8, 43, 0) 0%, rgba(2, 8, 43, .9) 38%, #02082b 100%);
      transition: transform .3s ease, opacity .3s ease;}
.mobile-only .sticky-cta.hidden {transform: translateX(-50%) translateY(120%);
      opacity: 0;
      pointer-events: none;}
.mobile-only .sticky-cta__btn {display: flex; align-items: center; justify-content: center; gap: 10px;
      width: 100%; height: 58px;
      border: 0; border-radius: 16px; cursor: pointer;
      color: #092b76;
      text-transform: uppercase;
      font-size: 22px; font-weight: 900; letter-spacing: .4px;
      background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
      box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, .55),
        inset 0 -5px 0 rgba(177, 91, 0, .36),
        0 -2px 24px rgba(255, 168, 0, .4);
      animation: ctaPulse 2.2s ease-in-out infinite;}
.mobile-only .sticky-cta__btn svg {width: 22px; height: 22px;}
@keyframes ctaPulse {0%, 100% { box-shadow: inset 0 2px 0 rgba(255, 255, 255, .55), inset 0 -5px 0 rgba(177, 91, 0, .36), 0 0 0 0 rgba(255, 168, 0, .5); }
      50% { box-shadow: inset 0 2px 0 rgba(255, 255, 255, .55), inset 0 -5px 0 rgba(177, 91, 0, .36), 0 0 0 10px rgba(255, 168, 0, 0); }}
@media (prefers-reduced-motion: reduce) {.mobile-only .sticky-cta__btn {animation: none;}}

.mobile-only .pov {position: fixed; inset: 0; z-index: 200;
      display: flex; align-items: center; justify-content: center;
      padding: 24px;
      background: rgba(0, 4, 18, .8);
      backdrop-filter: blur(6px);
      opacity: 0; pointer-events: none;
      transition: opacity .35s ease;}
.mobile-only .pov.on {opacity: 1; pointer-events: auto;}
.mobile-only .pbox {position: relative;
      width: min(420px, 100%);
      padding: 40px 30px;
      text-align: center;
      border: 2px solid transparent;
      border-radius: 28px;
      background:
        linear-gradient(180deg, rgba(7, 24, 74, .96) 0%, rgba(3, 13, 48, .96) 100%) padding-box,
        linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
      box-shadow: 0 0 26px var(--shadow-blue), 0 0 30px var(--shadow-red), 0 26px 60px rgba(0, 0, 0, .5);
      transform: scale(.82) translateY(28px);
      transition: transform .38s cubic-bezier(.34, 1.56, .64, 1);}
.mobile-only .pov.on .pbox {transform: scale(1) translateY(0);}
.mobile-only .pico {display: block; font-size: 58px; margin-bottom: 12px;}
.mobile-only .pttl {margin: 0 0 12px; color: var(--gold-400);
      text-transform: uppercase; font-size: 30px; font-weight: 900;
      letter-spacing: .4px; line-height: 1.05;}
.mobile-only .pmsg {margin: 0 0 26px; color: #fff;
      font-size: 18px; font-weight: 600; line-height: 1.5;}
.mobile-only .pcls {min-width: 180px; height: 56px; padding: 0 40px;
      border: 0; border-radius: 14px; cursor: pointer;
      color: #092b76; text-transform: uppercase;
      font-size: 22px; font-weight: 900; letter-spacing: .5px;
      background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
      box-shadow: inset 0 2px 0 rgba(255, 255, 255, .55), inset 0 -5px 0 rgba(177, 91, 0, .36), 0 12px 28px rgba(255, 168, 0, .34);
      transition: transform .18s ease, filter .18s ease;}
.mobile-only .pcls:active {transform: translateY(1px);}

:root {--navy-950: #02082b;
      --navy-900: #041144;
      --navy-800: #061b5d;
      --blue-600: #0068ff;
      --cyan-400: #00c8ff;
      --lime-400: #8fe600;
      --red-500: #ff2b16;
      --orange-500: #ff9e00;
      --gold-400: #ffd43b;
      --gold-500: #ffb800;
      --white: #ffffff;
      --muted: rgba(255,255,255,.72);
      --card-bg: rgba(4, 18, 68, .88);
      --border-soft: rgba(255,255,255,.18);
      --shadow-blue: rgba(0, 119, 255, .55);
      --shadow-red: rgba(255, 55, 25, .45);}
* {box-sizing: border-box;}
html {scroll-behavior: smooth;}
.desktop-only {margin: 0;
      min-height: 100vh;
      background: var(--navy-950);
      color: var(--white);
      font-family: "Be Vietnam Pro", "Montserrat", "Arial", sans-serif;
      overflow-x: hidden;}
.desktop-only a {color: inherit;
      text-decoration: none;}
.desktop-only button, .desktop-only input {font: inherit;}
.desktop-only .sr-only {position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;}
.desktop-only .site-header {position: fixed;
      top: 0;
      left: 0;
      right: 0;
      z-index: 50;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 24px;
      padding: 24px clamp(18px, 4.4vw, 74px);
      pointer-events: none;}
.desktop-only .logo-mark, .desktop-only .nav-links, .desktop-only .header-cta {pointer-events: auto;}
.desktop-only .logo-mark {min-width: 166px;
      height: 62px;
      display: inline-flex;
      align-items: center;
      padding-left: 34px;
      background: var(--white);
      color: #103c9a;
      font-size: 28px;
      font-weight: 900;
      letter-spacing: .2px;
      text-transform: uppercase;
      border-radius: 0 0 34px 0;
      clip-path: polygon(0 0, 100% 0, 86% 100%, 0 100%);
      box-shadow: 0 12px 30px rgba(0, 0, 0, .28);}
.desktop-only .nav-links {display: flex;
      align-items: center;
      gap: clamp(12px, 2vw, 28px);
      padding: 12px 22px;
      border: 1px solid rgba(255, 255, 255, .16);
      border-radius: 999px;
      background: rgba(1, 11, 48, .46);
      backdrop-filter: blur(10px);
      box-shadow: 0 12px 30px rgba(0, 0, 0, .16);}
.desktop-only .nav-links a {color: rgba(255, 255, 255, .86);
      font-size: 14px;
      font-weight: 800;
      transition: color .2s ease, transform .2s ease;}
.desktop-only .nav-links a:hover {color: var(--gold-400);
      transform: translateY(-1px);}
.desktop-only .header-cta {display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 46px;
      padding: 0 24px;
      border-radius: 999px;
      color: #092b76;
      font-weight: 900;
      text-transform: uppercase;
      background: linear-gradient(180deg, #fff36e 0%, var(--gold-500) 50%, #ff9c00 100%);
      box-shadow: 0 8px 0 rgba(146, 76, 0, .7), 0 14px 30px rgba(255, 184, 0, .35);
      transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;}
.desktop-only .header-cta:hover {transform: translateY(-3px);
      filter: brightness(1.08);
      box-shadow: 0 10px 0 rgba(146, 76, 0, .7), 0 18px 38px rgba(255, 184, 0, .48);}
.desktop-only .hero {position: relative;
      isolation: isolate;
      min-height: 100svh;
      display: flex;
      align-items: center;
      padding: max(112px, 8vh) clamp(18px, 5vw, 92px) 48px;
      overflow: hidden;
      background-image: url('hero-bg.webp');
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center center;
      background-color: var(--navy-950);}
.desktop-only .hero::before {content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        linear-gradient(90deg, rgba(2, 8, 43, 0) 0%, rgba(2, 8, 43, 0) 46%, rgba(2, 8, 43, .14) 58%, rgba(2, 8, 43, .78) 100%);
      pointer-events: none;}
.desktop-only .hero-inner {width: 100%;
      max-width: 1580px;
      min-height: calc(100svh - 160px);
      margin: 0 auto;
      display: grid;
      grid-template-columns: minmax(440px, 1.1fr) minmax(400px, 540px);
      align-items: center;
      gap: clamp(28px, 5vw, 76px);}
.desktop-only .hero-art-spacer {min-height: 540px;}
.desktop-only .form-card {position: relative;
      width: 100%;
      padding: clamp(24px, 2.5vw, 36px) clamp(22px, 3vw, 38px) 30px;
      border: 2px solid transparent;
      border-radius: 42px;
      background:
        linear-gradient(180deg, rgba(7, 24, 74, .92) 0%, rgba(3, 13, 48, .92) 100%) padding-box,
        linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
      box-shadow:
        0 0 22px var(--shadow-blue),
        0 0 26px var(--shadow-red),
        inset 0 0 34px rgba(0, 124, 255, .2),
        0 26px 60px rgba(0, 0, 0, .42);
      backdrop-filter: blur(8px);}
.desktop-only .form-title-wrap {text-align: center;
      margin-bottom: 12px;}
.desktop-only .form-title {position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 66px;
      padding: 6px clamp(30px, 4vw, 54px);
      color: #0c2d78;
      background: linear-gradient(180deg, #ffffff 0%, #f6f8ff 52%, #eef2ff 100%);
      border: 3px solid #ff8a0a;
      clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
      text-transform: uppercase;
      white-space: nowrap;
      font-size: clamp(28px, 2.9vw, 44px);
      font-weight: 900;
      line-height: 1;
      letter-spacing: -.8px;
      text-shadow: 0 2px 0 #ffffff, 0 4px 0 rgba(0, 36, 105, .12);
      box-shadow: 0 8px 20px rgba(0, 0, 0, .22);}
.desktop-only .form-subtitle {margin: 0 0 24px;
      color: rgba(255, 255, 255, .9);
      text-align: center;
      font-size: clamp(14px, 1.2vw, 18px);
      font-weight: 600;}
.desktop-only .field-group {display: grid;
      gap: 8px;
      margin-bottom: 16px;}
.desktop-only .field-label {display: flex;
      align-items: center;
      gap: 10px;
      color: #ffffff;
      font-size: clamp(14px, 1.15vw, 18px);
      font-weight: 800;}
.desktop-only .step-number {display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 30px;
      height: 30px;
      flex: 0 0 30px;
      border-radius: 8px;
      color: #09245e;
      font-size: 19px;
      font-weight: 900;
      background: linear-gradient(180deg, #ffe855 0%, #ffc400 100%);
      box-shadow: inset 0 -3px 0 rgba(180, 95, 0, .32);}
.desktop-only .input-control {width: 100%;
      height: 50px;
      border: 1.5px solid rgba(255, 255, 255, .34);
      border-radius: 12px;
      outline: none;
      color: #ffffff;
      background: rgba(5, 15, 52, .74);
      padding: 0 20px;
      font-size: clamp(14px, 1.12vw, 17px);
      font-weight: 600;
      transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;}
.desktop-only .input-control::placeholder {color: rgba(255, 255, 255, .46);}
.desktop-only .input-control:hover, .desktop-only .input-control:focus {border-color: rgba(0, 200, 255, .9);
      background: rgba(7, 24, 74, .86);
      box-shadow: 0 0 0 4px rgba(0, 200, 255, .12), 0 0 18px rgba(0, 200, 255, .18);}

.desktop-only .amount-type {display: flex;
      gap: 8px;
      margin-bottom: 8px;}
.desktop-only .amount-opt {flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 7px;
      height: 38px;
      border-radius: 9px;
      border: 1.5px solid rgba(255, 255, 255, .18);
      background: rgba(7, 24, 74, .6);
      color: rgba(255, 255, 255, .9);
      font-weight: 600;
      font-size: clamp(12px, .92vw, 14px);
      cursor: pointer;
      user-select: none;
      transition: border-color .18s ease, background .18s ease, color .18s ease;}
.desktop-only .amount-opt input {appearance: none;
      width: 15px;
      height: 15px;
      margin: 0;
      flex: 0 0 15px;
      border: 2px solid rgba(255, 255, 255, .55);
      border-radius: 50%;
      cursor: pointer;
      transition: border-color .18s ease, box-shadow .18s ease;}
.desktop-only .amount-opt input:checked {border-color: var(--gold-400);
      box-shadow: inset 0 0 0 3px var(--gold-400);}
.desktop-only .amount-opt:has(input:checked) {border-color: var(--gold-400);
      background: rgba(255, 212, 59, .12);
      color: var(--gold-400);}

.desktop-only #d-amount {height: clamp(54px, 7.5vh, 66px);
      font-size: clamp(18px, 1.9vw, 24px);
      font-weight: 800;
      letter-spacing: .3px;
      border-width: 2px;
      border-color: rgba(255, 212, 59, .42);}
.desktop-only #d-amount::placeholder {font-weight: 600;
      font-size: clamp(14px, 1.3vw, 17px);}
.desktop-only .confirm-row {display: flex;
      align-items: flex-start;
      gap: 12px;
      margin: 18px 0 22px;
      color: rgba(255, 255, 255, .95);
      font-size: clamp(14px, 1.12vw, 17px);
      font-weight: 600;
      line-height: 1.45;
      cursor: pointer;}
.desktop-only .confirm-row input {appearance: none;
      width: 32px;
      height: 32px;
      margin: 0;
      flex: 0 0 32px;
      border: 3px solid rgba(255, 255, 255, .85);
      border-radius: 8px;
      background: rgba(255, 255, 255, .03);
      cursor: pointer;
      transition: background-color .2s ease, box-shadow .2s ease, border-color .2s ease;}
.desktop-only .confirm-row input:checked {border-color: var(--gold-400);
      background:
        linear-gradient(135deg, transparent 0 42%, #092b76 42% 57%, transparent 57%),
        linear-gradient(45deg, transparent 0 52%, #092b76 52% 67%, transparent 67%),
        var(--gold-400);
      box-shadow: 0 0 16px rgba(255, 212, 59, .46);}
.desktop-only .submit-btn {position: relative;
      overflow: hidden;
      width: 100%;
      height: 70px;
      border: 0;
      border-radius: 18px;
      cursor: pointer;
      color: #092b76;
      text-transform: uppercase;
      font-size: clamp(28px, 3vw, 44px);
      font-weight: 900;
      letter-spacing: .5px;
      background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
      box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, .55),
        inset 0 -5px 0 rgba(177, 91, 0, .36),
        0 12px 28px rgba(255, 168, 0, .34);
      transition: transform .2s ease, filter .2s ease, box-shadow .2s ease;}

.desktop-only .submit-btn::before {content: "";
      position: absolute;
      inset: 0 0 42% 0;
      pointer-events: none;
      border-radius: inherit;
      background: linear-gradient(180deg,
        rgba(255, 255, 255, .65) 0%,
        rgba(255, 255, 255, .28) 45%,
        rgba(255, 255, 255, 0) 100%);
      mix-blend-mode: screen;
      opacity: .9;}

.desktop-only .submit-btn::after {content: "";
      position: absolute;
      top: -20%;
      left: 0;
      width: 45%;
      height: 140%;
      pointer-events: none;
      background: linear-gradient(
        100deg,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, .25) 30%,
        rgba(255, 255, 255, 1) 50%,
        rgba(255, 255, 255, .25) 70%,
        rgba(255, 255, 255, 0) 100%);
      filter: blur(1px);
      transform: translateX(-220%) skewX(-22deg);
      animation: btnShine 3.4s ease-in-out infinite;}
@keyframes btnShine {0%   { transform: translateX(-220%) skewX(-22deg); }
      18%  { transform: translateX(320%)  skewX(-22deg); }
      100% { transform: translateX(320%)  skewX(-22deg); }}
.desktop-only .submit-btn:hover::after {animation-duration: 1.1s;}
@media (prefers-reduced-motion: reduce) {.desktop-only .submit-btn::after {animation: none; opacity: 0;}.desktop-only .submit-btn::before {opacity: .5;}}
.desktop-only .submit-btn:hover {transform: translateY(-3px) scale(1.01);
      filter: brightness(1.08);
      box-shadow:
        inset 0 2px 0 rgba(255, 255, 255, .55),
        inset 0 -5px 0 rgba(177, 91, 0, .36),
        0 18px 36px rgba(255, 168, 0, .48);}
.desktop-only .submit-btn:active {transform: translateY(1px) scale(.995);}

.desktop-only .submit-btn-label {position: relative;
      z-index: 3;
      display: inline-block;}
.desktop-only .secure-note {display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      margin-top: 20px;
      color: rgba(255, 255, 255, .58);
      font-size: clamp(12px, 1vw, 15px);
      font-weight: 600;
      text-align: center;}

.desktop-only .hp-field {position: absolute !important;
      left: -9999px !important;
      width: 1px;
      height: 1px;
      opacity: 0;
      pointer-events: none;}
.desktop-only .pov {position: fixed;
      inset: 0;
      z-index: 200;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 24px;
      background: rgba(0, 4, 18, .8);
      backdrop-filter: blur(6px);
      opacity: 0;
      pointer-events: none;
      transition: opacity .35s ease;}
.desktop-only .pov.on {opacity: 1;
      pointer-events: auto;}
.desktop-only .pbox {position: relative;
      width: min(560px, 100%);
      padding: clamp(36px, 5vw, 54px) clamp(28px, 5vw, 64px);
      text-align: center;
      border: 2px solid transparent;
      border-radius: 32px;
      background:
        linear-gradient(180deg, rgba(7, 24, 74, .96) 0%, rgba(3, 13, 48, .96) 100%) padding-box,
        linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
      box-shadow: 0 0 26px var(--shadow-blue), 0 0 30px var(--shadow-red), 0 26px 60px rgba(0, 0, 0, .5);
      transform: scale(.82) translateY(28px);
      transition: transform .38s cubic-bezier(.34, 1.56, .64, 1);}
.desktop-only .pov.on .pbox {transform: scale(1) translateY(0);}
.desktop-only .pico {display: block;
      font-size: clamp(56px, 8vw, 72px);
      margin-bottom: 14px;}
.desktop-only .pttl {margin: 0 0 14px;
      color: var(--gold-400);
      text-transform: uppercase;
      font-size: clamp(30px, 4vw, 46px);
      font-weight: 900;
      letter-spacing: .4px;
      line-height: 1.05;}
.desktop-only .pmsg {margin: 0 0 18px;
      color: #ffffff;
      font-size: clamp(18px, 2.2vw, 26px);
      font-weight: 600;
      line-height: 1.5;}
.desktop-only .pcode-wrap {display: none;
      flex-direction: column;
      align-items: center;
      gap: 12px;
      margin: 0 0 28px;}
.desktop-only .pcode-wrap.show {display: flex;}
.desktop-only .psub {margin: 0 0 26px;
      color: rgba(255, 255, 255, .72);
      font-size: clamp(14px, 1.6vw, 18px);
      line-height: 1.5;
      font-weight: 500;}
.desktop-only .pcode {display: inline-block;
      padding: 14px 28px;
      border-radius: 14px;
      border: 2px dashed var(--gold-400);
      background: rgba(255, 212, 59, .08);
      color: var(--gold-400);
      font-family: "Courier New", ui-monospace, monospace;
      font-size: clamp(26px, 4vw, 40px);
      font-weight: 900;
      letter-spacing: 3px;
      user-select: all;}
.desktop-only .pcopy {height: 42px;
      padding: 0 24px;
      border: 1px solid rgba(255, 212, 59, .55);
      border-radius: 10px;
      cursor: pointer;
      background: rgba(255, 212, 59, .12);
      color: var(--gold-400);
      font-size: 15px;
      font-weight: 800;
      letter-spacing: .3px;
      transition: background .18s ease, transform .12s ease;}
.desktop-only .pcopy:hover {background: rgba(255, 212, 59, .22);}
.desktop-only .pcopy:active {transform: translateY(1px);}
.desktop-only .pcls {min-width: 200px;
      height: 60px;
      padding: 0 48px;
      border: 0;
      border-radius: 14px;
      cursor: pointer;
      color: #092b76;
      text-transform: uppercase;
      font-size: clamp(20px, 2.4vw, 28px);
      font-weight: 900;
      letter-spacing: .5px;
      background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
      box-shadow: inset 0 2px 0 rgba(255, 255, 255, .55), inset 0 -5px 0 rgba(177, 91, 0, .36), 0 12px 28px rgba(255, 168, 0, .34);
      transition: transform .18s ease, filter .18s ease;}
.desktop-only .pcls:hover {transform: translateY(-2px);
      filter: brightness(1.08);}
.desktop-only .pcls:active {transform: translateY(1px);}
@media (max-width: 1180px) {.desktop-only .site-header {padding-top: 18px;}.desktop-only .nav-links {display: none;}.desktop-only .hero {background-position: 42% center;}.desktop-only .hero-inner {grid-template-columns: minmax(300px, 1fr) minmax(400px, 540px);
        gap: 30px;}.desktop-only .hero-art-spacer {min-height: 520px;}}

:root {--hero-side-pad: clamp(14px, 4.4vw, 76px);}
.desktop-only {font-family: "Be Vietnam Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;}
.desktop-only .site-header {justify-content: center;
      padding: clamp(12px, 2.4vh, 20px) var(--hero-side-pad);}
.desktop-only .nav-links {padding: 9px 18px;
      gap: clamp(10px, 1.6vw, 24px);}
.desktop-only .nav-links a {font-size: clamp(12px, .9vw, 14px);}
.desktop-only .hero {min-height: 100svh;
      min-height: 100dvh;
      height: 100svh;
      height: 100dvh;
      padding: clamp(60px, 8vh, 86px) var(--hero-side-pad) clamp(14px, 3vh, 28px);
      align-items: center;
      background-size: cover;
      background-position: center center;}
.desktop-only .hero-inner {height: 100%;
      min-height: 0;
      max-width: 1480px;
      grid-template-columns: minmax(360px, 1.15fr) minmax(360px, 500px);
      gap: clamp(18px, 4vw, 58px);
      align-items: center;}
.desktop-only .hero-art-spacer {min-height: 0;}
.desktop-only .form-card {max-width: 500px;
      padding: clamp(18px, 2.1vw, 28px) clamp(18px, 2.4vw, 30px) clamp(16px, 2vw, 24px);
      border-radius: clamp(26px, 2.6vw, 36px);}
.desktop-only .form-title-wrap {margin-bottom: 8px;}
.desktop-only .form-title {min-height: clamp(46px, 6.2vh, 58px);
      padding: 5px clamp(26px, 3vw, 44px);
      font-size: clamp(25px, 2.55vw, 38px);
      letter-spacing: -.6px;}
.desktop-only .form-subtitle {margin-bottom: clamp(10px, 1.8vh, 16px);
      font-size: clamp(12px, 1vw, 15px);
      line-height: 1.35;}
.desktop-only .field-group {gap: 5px;
      margin-bottom: clamp(8px, 1.25vh, 12px);}
.desktop-only .field-label {gap: 8px;
      font-size: clamp(12px, .95vw, 15px);
      line-height: 1.2;}
.desktop-only .step-number {width: clamp(22px, 2.8vh, 28px);
      height: clamp(22px, 2.8vh, 28px);
      flex-basis: clamp(22px, 2.8vh, 28px);
      font-size: clamp(14px, 1.65vh, 17px);
      border-radius: 7px;}
.desktop-only .input-control {height: clamp(38px, 5.2vh, 46px);
      border-radius: 10px;
      padding: 0 14px;
      font-size: clamp(12px, .95vw, 15px);}
.desktop-only .confirm-row {gap: 10px;
      margin: clamp(8px, 1.4vh, 13px) 0 clamp(10px, 1.6vh, 15px);
      font-size: clamp(12px, .95vw, 15px);
      line-height: 1.35;}
.desktop-only .confirm-row input {width: clamp(22px, 3vh, 28px);
      height: clamp(22px, 3vh, 28px);
      flex-basis: clamp(22px, 3vh, 28px);
      border-width: 2px;
      border-radius: 7px;}
.desktop-only .submit-btn {height: clamp(46px, 6.4vh, 58px);
      border-radius: 14px;
      font-size: clamp(22px, 2.45vw, 34px);}
.desktop-only .secure-note {margin-top: clamp(8px, 1.4vh, 14px);
      font-size: clamp(10px, .8vw, 12px);
      line-height: 1.25;}
@media (max-height: 760px) and (min-width: 921px) {.desktop-only .hero {padding-top: 56px;
        padding-bottom: 12px;}.desktop-only .form-card {max-width: 470px;
        padding: 16px 22px 16px;}.desktop-only .form-title {min-height: 44px;
        font-size: 28px;}.desktop-only .form-subtitle {margin-bottom: 9px;}.desktop-only .input-control {height: 38px;}.desktop-only .field-group {margin-bottom: 7px;}.desktop-only .submit-btn {height: 46px;}.desktop-only .secure-note {margin-top: 7px;}}
@media (max-width: 1180px) {.desktop-only .hero-inner {grid-template-columns: minmax(280px, 1fr) minmax(340px, 470px);
        gap: 24px;}.desktop-only .hero {background-position: 38% center;}}

.desktop-only .section {position: relative;
      overflow: hidden;
      padding: clamp(58px, 7vw, 108px) clamp(18px, 5vw, 92px);}
.desktop-only .section--benefits {background:
        radial-gradient(120% 80% at 15% -10%, rgba(0, 104, 255, .30), transparent 55%),
        radial-gradient(120% 80% at 92% 8%, rgba(255, 43, 22, .18), transparent 52%),
        linear-gradient(180deg, #02082b 0%, #051a55 100%);}
.desktop-only .section--steps {background:
        radial-gradient(120% 90% at 50% -10%, rgba(143, 230, 0, .10), transparent 60%),
        linear-gradient(180deg, #051a55 0%, #02082b 100%);}
.desktop-only .sec-glow {position: absolute;
      inset: 0;
      pointer-events: none;
      background: radial-gradient(50% 42% at 50% 0%, rgba(255, 212, 59, .12), transparent 70%);}
.desktop-only .sec-head {position: relative;
      text-align: center;
      max-width: 840px;
      margin: 0 auto clamp(40px, 5vw, 70px);}
.desktop-only .sec-kicker {display: inline-flex;
      align-items: center;
      gap: 10px;
      margin: 0 0 16px;
      padding: 8px 18px;
      border-radius: 999px;
      border: 1px solid rgba(255, 212, 59, .4);
      background: rgba(255, 212, 59, .08);
      color: var(--gold-400);
      font-weight: 800;
      font-size: 13px;
      text-transform: uppercase;
      letter-spacing: .16em;}
.desktop-only .sec-kicker::before {content: "";
      width: 8px;
      height: 8px;
      border-radius: 50%;
      background: var(--gold-400);
      box-shadow: 0 0 10px var(--gold-400);}
.desktop-only .sec-title {margin: 0;
      color: #fff;
      font-size: clamp(30px, 4.4vw, 56px);
      font-weight: 900;
      line-height: 1.06;
      text-transform: uppercase;
      text-wrap: balance;
      text-shadow: 0 5px 0 rgba(0, 0, 0, .22);}
.desktop-only .sec-title b {color: var(--gold-400);}

.desktop-only .podium-card {position: relative;
      width: 100%;
      max-width: 560px;
      margin: 0 auto;
      padding: 0;
      filter: drop-shadow(0 26px 44px rgba(0, 0, 0, .55)) drop-shadow(0 0 34px rgba(0, 140, 255, .32));
      animation: podiumFloat 5.5s ease-in-out infinite;}
.desktop-only .podium-card__img {display: block;
      width: 100%;
      height: auto;}
@keyframes podiumFloat {0%, 100% { transform: translateY(0); }
      50%      { transform: translateY(-12px); }}
@media (prefers-reduced-motion: reduce) {.desktop-only .podium-card {animation: none;}}

.desktop-only .steps-rail {position: relative;
      max-width: 1040px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: clamp(20px, 3vw, 46px);}
.desktop-only .steps-rail::before {content: "";
      position: absolute;
      top: 46px;
      left: 16%;
      right: 16%;
      height: 2px;
      background: repeating-linear-gradient(90deg, rgba(255, 212, 59, .55) 0 14px, transparent 14px 28px);}
.desktop-only .step {position: relative;
      text-align: center;}
.desktop-only .step__node {position: relative;
      z-index: 1;
      width: 92px;
      height: 92px;
      margin: 0 auto 22px;
      border-radius: 24px;
      display: grid;
      place-items: center;
      color: #fff;
      background: linear-gradient(160deg, #0a3aa0, #061b5d);
      border: 2px solid rgba(0, 200, 255, .5);
      box-shadow: 0 0 26px rgba(0, 124, 255, .4), inset 0 0 20px rgba(0, 124, 255, .25);}
.desktop-only .step__node svg {width: 40px;
      height: 40px;}
.desktop-only .step__no {position: absolute;
      top: -12px;
      right: -12px;
      width: 36px;
      height: 36px;
      border-radius: 50%;
      display: grid;
      place-items: center;
      color: #09245e;
      font-weight: 900;
      font-size: 16px;
      background: linear-gradient(180deg, #ffe855, #ffc400);
      box-shadow: 0 6px 14px rgba(0, 0, 0, .4);}
.desktop-only .step__title {margin: 0 0 8px;
      color: #fff;
      font-weight: 800;
      font-size: clamp(18px, 1.9vw, 24px);
      text-transform: uppercase;}
.desktop-only .step__desc {margin: 0 auto;
      max-width: 300px;
      color: var(--muted);
      font-size: 15px;
      line-height: 1.6;
      font-weight: 500;}

.desktop-only .step {transition: transform .45s ease;}
.desktop-only .step__node {transition: border-color .45s ease, box-shadow .45s ease, transform .45s ease, color .45s ease;}
.desktop-only .step__no {transition: box-shadow .45s ease, transform .45s ease;}

.desktop-only .steps-rail.anim .step {opacity: 0;
      transform: translateY(30px);}
.desktop-only .steps-rail.anim.lit .step {animation: stepIn .65s cubic-bezier(.34, 1.56, .64, 1) forwards;}
.desktop-only .steps-rail.anim.lit .step:nth-child(1) {animation-delay: .10s;}
.desktop-only .steps-rail.anim.lit .step:nth-child(2) {animation-delay: .30s;}
.desktop-only .steps-rail.anim.lit .step:nth-child(3) {animation-delay: .50s;}
@keyframes stepIn {to { opacity: 1; transform: translateY(0); }}

.desktop-only .step.is-active {transform: translateY(-8px);}
.desktop-only .step.is-active .step__node {color: #bdeaff;
      border-color: rgba(130, 230, 255, .95);
      box-shadow: 0 0 40px rgba(0, 200, 255, .9), inset 0 0 24px rgba(0, 200, 255, .5);
      transform: scale(1.12);}
.desktop-only .step.is-active .step__no {box-shadow: 0 0 18px rgba(255, 200, 0, .9), 0 6px 14px rgba(0, 0, 0, .45);
      transform: scale(1.08);}

.desktop-only .steps-rail::after {content: "";
      position: absolute;
      top: 46px;
      left: 16%;
      height: 2px;
      width: var(--rail-progress, 0%);
      max-width: 68%;
      background: linear-gradient(90deg, var(--cyan-400), var(--gold-400));
      box-shadow: 0 0 12px rgba(0, 200, 255, .7);
      transition: width .6s ease;
      z-index: 0;}
@media (prefers-reduced-motion: reduce) {.desktop-only .steps-rail.anim .step {opacity: 1; transform: none;}.desktop-only .step.is-active, .desktop-only .step.is-active .step__node, .desktop-only .step.is-active .step__no {transform: none;}.desktop-only .steps-rail::after {display: none;}}

.desktop-only .foot {padding: 30px clamp(18px, 5vw, 92px);
      background: #01051d;
      border-top: 1px solid rgba(255, 255, 255, .1);
      color: rgba(255, 255, 255, .6);
      font-size: 14px;}
.desktop-only .foot__in {max-width: 1080px;
      margin: 0 auto;
      display: flex;
      gap: 16px;
      align-items: center;
      justify-content: space-between;
      flex-wrap: wrap;}
.desktop-only .foot__links {display: flex;
      gap: 18px;
      flex-wrap: wrap;}
.desktop-only .foot a:hover {color: var(--gold-400);}

.desktop-only .sticky-cta {display: none;}

.shared-form-mount {
  width: 100%;
}
.desktop-only .shared-form-mount {
  width: 100%;
  max-width: 540px;
  justify-self: end;
  align-self: center;
}
.mobile-only .shared-form-mount {
  width: 100%;
}

.form-logo {
  display: block;
  width: 65%;
  margin: 0 auto 2%;
}

.mobile-only .shared-register-form.form-card,
.desktop-only .shared-register-form.form-card {
  position: relative;
  width: 100%;
  isolation: isolate;
  color: #fff;
  border: 2px solid transparent;
  background:
    linear-gradient(180deg, rgba(7, 24, 74, .94) 0%, rgba(3, 13, 48, .95) 100%) padding-box,
    linear-gradient(135deg, var(--lime-400) 0%, var(--cyan-400) 32%, #315eff 49%, var(--red-500) 77%, #ff6c12 100%) border-box;
  box-shadow:
    0 0 22px var(--shadow-blue),
    0 0 26px var(--shadow-red),
    inset 0 0 34px rgba(0, 124, 255, .18),
    0 26px 60px rgba(0, 0, 0, .42);
  backdrop-filter: blur(8px);
}
.mobile-only .shared-register-form.form-card {
  padding: 19px 14px 13px;
  border-radius: 30px;
}
.desktop-only .shared-register-form.form-card {
  padding: clamp(24px, 2.5vw, 36px) clamp(22px, 3vw, 38px) 30px;
  border-radius: 42px;
}

.shared-register-form .form-title-wrap {
  text-align: center;
}
.mobile-only .shared-register-form .form-title-wrap { margin-bottom: 5px; }
.desktop-only .shared-register-form .form-title-wrap { margin-bottom: 12px; }

.shared-register-form .form-title {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #0c2d78;
  background: linear-gradient(180deg, #ffffff 0%, #f6f8ff 52%, #eef2ff 100%);
  border: 3px solid #ff8a0a;
  clip-path: polygon(8% 0, 92% 0, 100% 50%, 92% 100%, 8% 100%, 0 50%);
  text-transform: uppercase;
  white-space: nowrap;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.8px;
  text-shadow: 0 2px 0 #ffffff, 0 4px 0 rgba(0, 36, 105, .12);
  box-shadow: 0 8px 20px rgba(0, 0, 0, .22);
}
.mobile-only .shared-register-form .form-title {
  min-height: 38px;
  padding: 4px 22px;
  font-size: clamp(22px, 6.3vw, 31px);
}
.desktop-only .shared-register-form .form-title {
  min-height: 66px;
  padding: 6px clamp(30px, 4vw, 54px);
  font-size: clamp(28px, 2.9vw, 44px);
}

.shared-register-form .form-subtitle {
  color: rgba(255, 255, 255, .9);
  text-align: center;
  font-weight: 600;
  line-height: 1.35;
}
.mobile-only .shared-register-form .form-subtitle {
  margin: 0 0 9px;
  font-size: clamp(11px, 3.2vw, 14px);
}
.desktop-only .shared-register-form .form-subtitle {
  margin: 0 0 24px;
  font-size: clamp(14px, 1.2vw, 18px);
}

.shared-register-form .field-group {
  display: grid;
}
.mobile-only .shared-register-form .field-group {
  gap: 4px;
  margin-bottom: 7px;
}
.desktop-only .shared-register-form .field-group {
  gap: 8px;
  margin-bottom: 16px;
}

.shared-register-form .field-label {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #ffffff;
  font-weight: 800;
}
.mobile-only .shared-register-form .field-label {
  font-size: clamp(12px, 3.45vw, 15px);
  line-height: 1.1;
}
.desktop-only .shared-register-form .field-label {
  font-size: clamp(14px, 1.15vw, 18px);
}

.shared-register-form .step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  border-radius: 8px;
  color: #09245e;
  font-weight: 900;
  background: linear-gradient(180deg, #ffe855 0%, #ffc400 100%);
  box-shadow: inset 0 -3px 0 rgba(180, 95, 0, .32);
}
.mobile-only .shared-register-form .step-number {
  width: 24px;
  height: 24px;
  font-size: 15px;
}
.desktop-only .shared-register-form .step-number {
  width: 30px;
  height: 30px;
  font-size: 19px;
}

.shared-register-form .input-control {
  width: 100%;
  border: 1.5px solid rgba(255, 255, 255, .34);
  outline: none;
  color: #ffffff;
  background: rgba(5, 15, 52, .74);
  font-weight: 600;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease, transform .2s ease;
}
.mobile-only .shared-register-form .input-control {
  height: 38px;
  padding: 0 13px;
  border-radius: 10px;
  font-size: 13.5px;
}
.desktop-only .shared-register-form .input-control {
  height: 50px;
  padding: 0 20px;
  border-radius: 12px;
  font-size: clamp(14px, 1.12vw, 17px);
}
.shared-register-form .input-control::placeholder {
  color: rgba(255, 255, 255, .46);
}
.shared-register-form.is-locked {
  opacity: .6;
  filter: saturate(.5);
}
.shared-register-form.is-locked .submit-btn {
  cursor: not-allowed;
}
.shared-register-form .input-control:hover,
.shared-register-form .input-control:focus {
  border-color: rgba(0, 200, 255, .9);
  background: rgba(7, 24, 74, .86);
  box-shadow: 0 0 0 4px rgba(0, 200, 255, .12), 0 0 18px rgba(0, 200, 255, .18);
}
.shared-register-form .input-control:focus {
  transform: translateY(-1px);
}

.shared-register-form .amount-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.mobile-only .shared-register-form .amount-toggle { gap: 6px; }
.desktop-only .shared-register-form .amount-toggle { margin-bottom: 8px; }

.shared-register-form .amt-opt {
  position: relative;
  cursor: pointer;
  user-select: none;
}
.shared-register-form .amt-opt input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  margin: 0;
}
.shared-register-form .amt-opt span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  border: 1.5px solid rgba(255, 255, 255, .18);
  background: rgba(7, 24, 74, .6);
  color: rgba(255, 255, 255, .9);
  font-weight: 700;
  transition: border-color .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}
.mobile-only .shared-register-form .amt-opt span {
  min-height: 34px;
  border-radius: 9px;
  font-size: 12px;
}
.desktop-only .shared-register-form .amt-opt span {
  min-height: 38px;
  border-radius: 9px;
  font-size: clamp(12px, .92vw, 14px);
}
.shared-register-form .amt-opt span::before {
  content: "";
  width: 15px;
  height: 15px;
  flex: 0 0 15px;
  border: 2px solid rgba(255, 255, 255, .55);
  border-radius: 50%;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.shared-register-form .amt-opt input:checked + span {
  border-color: var(--gold-400);
  background: rgba(255, 212, 59, .12);
  color: var(--gold-400);
}
.shared-register-form .amt-opt input:checked + span::before {
  border-color: var(--gold-400);
  box-shadow: inset 0 0 0 3px var(--gold-400);
}
.shared-register-form .amt-opt input:focus-visible + span {
  outline: 2px solid var(--cyan-400);
  outline-offset: 2px;
}

.shared-register-form .confirm-row {
  display: flex;
  align-items: flex-start;
  color: rgba(255, 255, 255, .95);
  font-weight: 600;
  line-height: 1.45;
  cursor: pointer;
}
.mobile-only .shared-register-form .confirm-row {
  gap: 10px;
  margin: 10px 0 12px;
  font-size: 12px;
}
.desktop-only .shared-register-form .confirm-row {
  gap: 12px;
  margin: 18px 0 22px;
  font-size: clamp(14px, 1.12vw, 17px);
}
.shared-register-form .confirm-row input {
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  flex: 0 0 auto;
  border: 3px solid rgba(255, 255, 255, .85);
  border-radius: 8px;
  background: rgba(255, 255, 255, .03);
  cursor: pointer;
  transition: background-color .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.mobile-only .shared-register-form .confirm-row input {
  width: 25px;
  height: 25px;
}
.desktop-only .shared-register-form .confirm-row input {
  width: 32px;
  height: 32px;
}
.shared-register-form .confirm-row input:checked {
  border-color: var(--gold-400);
  background:
    linear-gradient(135deg, transparent 0 42%, #092b76 42% 57%, transparent 57%),
    linear-gradient(45deg, transparent 0 52%, #092b76 52% 67%, transparent 67%),
    var(--gold-400);
  box-shadow: 0 0 16px rgba(255, 212, 59, .46);
}

.shared-register-form .hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.shared-register-form .submit-btn {
  position: relative;
  overflow: hidden;
  width: 100%;
  border: 0;
  cursor: pointer;
  color: #092b76;
  text-transform: uppercase;
  font-weight: 900;
  letter-spacing: .5px;
  background: linear-gradient(180deg, #fff466 0%, #ffd037 28%, #ffb000 58%, #ff9300 100%);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, .55),
    inset 0 -5px 0 rgba(177, 91, 0, .36),
    0 12px 28px rgba(255, 168, 0, .34);
  transition: transform .2s ease, filter .2s ease, box-shadow .2s ease, opacity .2s ease;
}
.mobile-only .shared-register-form .submit-btn {
  height: 48px;
  border-radius: 13px;
  font-size: clamp(25px, 7.4vw, 34px);
}
.desktop-only .shared-register-form .submit-btn {
  height: 70px;
  border-radius: 18px;
  font-size: clamp(28px, 3vw, 44px);
}
.shared-register-form .submit-btn[disabled] {
  cursor: wait;
  opacity: .78;
  filter: saturate(.85);
}
.shared-register-form .submit-btn:hover:not([disabled]) {
  transform: translateY(-3px) scale(1.01);
  filter: brightness(1.08);
  box-shadow:
    inset 0 2px 0 rgba(255, 255, 255, .55),
    inset 0 -5px 0 rgba(177, 91, 0, .36),
    0 18px 36px rgba(255, 168, 0, .48);
}
.shared-register-form .submit-btn:active:not([disabled]) {
  transform: translateY(1px) scale(.995);
}
.shared-register-form .submit-btn-label {
  position: relative;
  z-index: 3;
  display: inline-block;
}

.shared-register-form .secure-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: rgba(255, 255, 255, .58);
  text-align: center;
  line-height: 1.35;
}
.mobile-only .shared-register-form .secure-note {
  margin-top: 10px;
  font-size: 10.5px;
}
.desktop-only .shared-register-form .secure-note {
  margin-top: 20px;
  font-size: clamp(12px, 1vw, 15px);
}

@media (max-width: 360px) {
  .mobile-only .shared-register-form.form-card {
    padding: 17px 12px 12px;
    border-radius: 26px;
  }
  .mobile-only .shared-register-form .input-control { height: 35px; }
  .mobile-only .shared-register-form .submit-btn { height: 44px; }
}

@media (min-width: 768px) {
  .desktop-only .shared-form-mount {
    width: 100%;
    max-width: 540px;
    justify-self: end;
    align-self: center;
  }

  .desktop-only .shared-register-form.form-card {
    width: 100%;
    max-width: 540px;
    min-height: auto;
    max-height: none;
    padding: clamp(24px, 2.5vw, 36px) clamp(22px, 3vw, 38px) 30px;
    border-radius: 42px;
    transform: none;
    overflow: visible;
  }

  .desktop-only .shared-register-form .form-title-wrap {
    margin-bottom: 12px;
  }

  .desktop-only .shared-register-form .form-title {
    min-height: 66px;
    padding: 6px clamp(30px, 4vw, 54px);
    font-size: clamp(28px, 2.9vw, 44px);
    line-height: 1;
  }

  .desktop-only .shared-register-form .form-subtitle {
    margin: 0 0 24px;
    font-size: clamp(14px, 1.2vw, 18px);
    line-height: 1.35;
  }

  .desktop-only .shared-register-form .field-group {
    gap: 8px;
    margin-bottom: 16px;
  }

  .desktop-only .shared-register-form .field-label {
    gap: 10px;
    font-size: clamp(14px, 1.15vw, 18px);
    line-height: 1.2;
  }

  .desktop-only .shared-register-form .step-number {
    width: 30px;
    height: 30px;
    flex: 0 0 30px;
    font-size: 19px;
    border-radius: 8px;
  }

  .desktop-only .shared-register-form .input-control {
    height: 50px;
    padding: 0 20px;
    border-radius: 12px;
    font-size: clamp(14px, 1.12vw, 17px);
  }

  .desktop-only .shared-register-form .amount-toggle {
    display: flex;
    gap: 8px;
    margin-bottom: 8px;
  }

  .desktop-only .shared-register-form .amt-opt {
    flex: 1;
  }

  .desktop-only .shared-register-form .amt-opt span {
    min-height: 38px;
    height: 38px;
    border-radius: 9px;
    gap: 7px;
    font-size: clamp(12px, .92vw, 14px);
    font-weight: 600;
  }

  .desktop-only .shared-register-form .amt-opt span::before {
    width: 15px;
    height: 15px;
    flex: 0 0 15px;
  }

  .desktop-only .shared-register-form input[data-field="amount"] {
    height: clamp(54px, 7.5vh, 66px);
    font-size: clamp(18px, 1.9vw, 24px);
    font-weight: 800;
    letter-spacing: .3px;
    border-width: 2px;
    border-color: rgba(255, 212, 59, .42);
  }

  .desktop-only .shared-register-form input[data-field="amount"]::placeholder {
    font-weight: 600;
    font-size: clamp(14px, 1.3vw, 17px);
  }

  .desktop-only .shared-register-form .confirm-row {
    gap: 12px;
    margin: 18px 0 22px;
    font-size: clamp(14px, 1.12vw, 17px);
    line-height: 1.45;
  }

  .desktop-only .shared-register-form .confirm-row input {
    width: 32px;
    height: 32px;
    flex: 0 0 32px;
    border-radius: 8px;
  }

  .desktop-only .shared-register-form .submit-btn {
    height: 70px;
    border-radius: 18px;
    font-size: clamp(28px, 3vw, 44px);
  }

  .desktop-only .shared-register-form .secure-note {
    margin-top: 20px;
    font-size: clamp(12px, 1vw, 15px);
  }
}

@media (min-width: 768px) {
  .desktop-only .site-header {
    padding-top: clamp(10px, 1.5vh, 16px);
    padding-bottom: clamp(8px, 1.2vh, 14px);
  }

  .desktop-only .hero {
    height: 100dvh;
    min-height: 640px;
    max-height: 100dvh;
    overflow: hidden;
    padding-top: clamp(52px, 6.2vh, 70px);
    padding-bottom: clamp(8px, 1.4vh, 18px);
  }

  .desktop-only .hero-inner {
    height: 100%;
    max-height: calc(100dvh - 72px);
    align-items: center;
    grid-template-columns: minmax(360px, 1.16fr) minmax(420px, 540px);
    gap: clamp(20px, 4vw, 64px);
  }

  .desktop-only .shared-form-mount {
    width: min(100%, 540px);
    max-width: 540px;
    align-self: center;
    justify-self: end;
  }

  .desktop-only .shared-register-form.form-card {
    max-width: 540px;
    max-height: calc(100dvh - 104px);
    padding: clamp(16px, 1.8vh, 22px) clamp(24px, 2.2vw, 34px) clamp(14px, 1.6vh, 20px);
    border-radius: clamp(30px, 2.35vw, 38px);
    overflow: visible;
  }

  .desktop-only .shared-register-form .form-title-wrap {
    margin-bottom: clamp(6px, .9vh, 10px);
  }

  .desktop-only .shared-register-form .form-title {
    min-height: clamp(46px, 5.6vh, 58px);
    padding: 5px clamp(28px, 3.2vw, 48px);
    font-size: clamp(28px, 2.55vw, 40px);
    line-height: .98;
  }

  .desktop-only .shared-register-form .form-subtitle {
    margin-bottom: clamp(10px, 1.3vh, 14px);
    font-size: clamp(13px, 1.02vw, 16px);
    line-height: 1.28;
  }

  .desktop-only .shared-register-form .field-group {
    gap: clamp(4px, .65vh, 6px);
    margin-bottom: clamp(8px, 1vh, 11px);
  }

  .desktop-only .shared-register-form .field-label {
    gap: 8px;
    font-size: clamp(13px, 1vw, 16px);
    line-height: 1.15;
  }

  .desktop-only .shared-register-form .step-number {
    width: clamp(24px, 2.9vh, 28px);
    height: clamp(24px, 2.9vh, 28px);
    flex: 0 0 clamp(24px, 2.9vh, 28px);
    font-size: clamp(15px, 1.65vh, 18px);
    border-radius: 8px;
  }

  .desktop-only .shared-register-form .input-control {
    height: clamp(39px, 4.7vh, 46px);
    padding: 0 16px;
    border-radius: 11px;
    font-size: clamp(13px, 1vw, 16px);
  }

  .desktop-only .shared-register-form .amount-toggle {
    gap: 8px;
    margin-bottom: clamp(5px, .7vh, 8px);
  }

  .desktop-only .shared-register-form .amt-opt span {
    min-height: clamp(32px, 3.7vh, 36px);
    height: clamp(32px, 3.7vh, 36px);
    border-radius: 9px;
    font-size: clamp(12px, .9vw, 14px);
  }

  .desktop-only .shared-register-form input[data-field="amount"] {
    height: clamp(42px, 5vh, 48px);
    font-size: clamp(15px, 1.35vw, 19px);
  }

  .desktop-only .shared-register-form input[data-field="amount"]::placeholder {
    font-size: clamp(13px, 1vw, 15px);
  }

  .desktop-only .shared-register-form .confirm-row {
    gap: 10px;
    margin: clamp(8px, 1vh, 11px) 0 clamp(9px, 1.1vh, 13px);
    font-size: clamp(13px, 1vw, 16px);
    line-height: 1.28;
  }

  .desktop-only .shared-register-form .confirm-row input {
    width: clamp(24px, 3vh, 30px);
    height: clamp(24px, 3vh, 30px);
    flex: 0 0 clamp(24px, 3vh, 30px);
    border-width: 2px;
  }

  .desktop-only .shared-register-form .submit-btn {
    height: clamp(48px, 5.8vh, 56px);
    border-radius: 15px;
    font-size: clamp(24px, 2.35vw, 36px);
  }

  .desktop-only .shared-register-form .secure-note {
    margin-top: clamp(7px, .9vh, 10px);
    font-size: clamp(10px, .78vw, 12px);
    line-height: 1.2;
  }
}

@media (min-width: 768px) and (max-height: 760px) {
  .desktop-only .hero {
    min-height: 600px;
    padding-top: 48px;
    padding-bottom: 8px;
  }

  .desktop-only .hero-inner {
    max-height: calc(100dvh - 60px);
  }

  .desktop-only .shared-form-mount {
    max-width: 500px;
  }

  .desktop-only .shared-register-form.form-card {
    max-width: 500px;
    padding: 14px 24px 14px;
    border-radius: 30px;
  }

  .desktop-only .shared-register-form .form-title {
    min-height: 42px;
    font-size: 30px;
  }

  .desktop-only .shared-register-form .form-subtitle {
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 1.22;
  }

  .desktop-only .shared-register-form .field-group {
    gap: 4px;
    margin-bottom: 7px;
  }

  .desktop-only .shared-register-form .field-label {
    font-size: 13px;
  }

  .desktop-only .shared-register-form .step-number {
    width: 23px;
    height: 23px;
    flex-basis: 23px;
    font-size: 15px;
  }

  .desktop-only .shared-register-form .input-control {
    height: 36px;
    font-size: 13px;
  }

  .desktop-only .shared-register-form .amt-opt span {
    min-height: 30px;
    height: 30px;
  }

  .desktop-only .shared-register-form input[data-field="amount"] {
    height: 38px;
  }

  .desktop-only .shared-register-form .confirm-row {
    margin: 7px 0 8px;
    font-size: 13px;
  }

  .desktop-only .shared-register-form .confirm-row input {
    width: 24px;
    height: 24px;
    flex-basis: 24px;
  }

  .desktop-only .shared-register-form .submit-btn {
    height: 44px;
    font-size: 25px;
  }

  .desktop-only .shared-register-form .secure-note {
    margin-top: 6px;
  }
}

@media (min-width: 768px) and (max-width: 1180px) {
  .desktop-only .hero-inner {
    grid-template-columns: minmax(280px, 1fr) minmax(350px, 500px);
    gap: clamp(14px, 2.2vw, 26px);
  }

  .desktop-only .shared-form-mount {
    max-width: 500px;
  }
}

.shared-register-form .form-title {
  font-size: calc(var(--form-title-size, clamp(24px, 7.2vw, 36px)) * 0.85) !important;
}

.shared-register-form .submit-btn,
.shared-register-form button[type="submit"] {
  font-size: calc(var(--submit-btn-size, clamp(30px, 8.9vw, 43px)) * 0.85) !important;
}

@media (min-width: 768px) {
  .desktop-only .shared-register-form .form-title {
    font-size: calc(var(--desktop-form-title-size, 48px) * 0.7225) !important;
  }

  .desktop-only .shared-register-form .submit-btn,
  .desktop-only .shared-register-form button[type="submit"] {
    font-size: calc(var(--desktop-submit-btn-size, 42px) * 0.7225) !important;
  }
}

@media (min-width: 768px) {
  .desktop-only .reward-row {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(16px, 2.4vw, 30px);
    align-items: end;
    max-width: 1080px;
    margin: 0 auto;
  }

  .desktop-only .reward {
    position: relative;
    text-align: center;
    border-radius: 30px;
    padding: clamp(28px, 2.8vw, 40px) clamp(18px, 2vw, 28px) clamp(26px, 2.6vw, 34px);
    border: 2px solid transparent;
    background:
      linear-gradient(180deg, rgba(8, 32, 98, .9), rgba(4, 14, 52, .94)) padding-box,
      linear-gradient(160deg, var(--cyan-400), #315eff 55%, #0b2a86) border-box;
    box-shadow: inset 0 0 34px rgba(0, 124, 255, .18), 0 22px 50px rgba(0, 0, 0, .4);
  }

  .desktop-only .reward--mid {
    transform: translateY(-30px);
    background:
      linear-gradient(180deg, rgba(14, 40, 116, .95), rgba(6, 18, 64, .96)) padding-box,
      linear-gradient(160deg, #ffe87a, var(--gold-500) 55%, #ff8a0a) border-box;
    box-shadow: inset 0 0 40px rgba(255, 184, 0, .16), 0 0 32px rgba(255, 184, 0, .34), 0 26px 60px rgba(0, 0, 0, .5);
  }

  .desktop-only .reward__tag {
    display: inline-block;
    margin-bottom: 14px;
    padding: 6px 16px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: #cfe0ff;
    background: rgba(0, 124, 255, .18);
    border: 1px solid rgba(0, 200, 255, .3);
  }

  .desktop-only .reward--mid .reward__tag {
    color: #1a1300;
    background: linear-gradient(180deg, #ffe855, #ffc400);
    border-color: transparent;
  }

  .desktop-only .reward__num {
    font-size: clamp(46px, 6.4vw, 86px);
    font-weight: 900;
    line-height: .95;
    letter-spacing: -2px;
    background: linear-gradient(180deg, #fff, #ffd43b 60%, #ff9e00);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow: 0 0 24px rgba(255, 184, 0, .18);
  }

  .desktop-only .reward__label {
    margin: 8px 0 10px;
    color: #fff;
    font-weight: 800;
    text-transform: uppercase;
    font-size: clamp(15px, 1.4vw, 19px);
    letter-spacing: .04em;
  }

  .desktop-only .reward__desc {
    margin: 0;
    color: var(--muted);
    font-size: 15px;
    line-height: 1.6;
    font-weight: 500;
  }
}

@media (min-width: 768px) and (max-width: 920px) {
  .desktop-only .reward-row {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .desktop-only .reward--mid {
    transform: none;
  }
}
