:root {
  --ssg-red: #ef1d24;
  --ssg-blue: #1555ab;
  --ssg-green: #08c954;
  --ssg-dark: #071323;
  --ssg-white: #fff;
  --ssg-off: #ebebeb;
  --ssg-text: #f3f5f8;
}
.ssg-notice_b {
    font-size: small;
    color: #000;
    font-weight: 600;
    text-wrap-style: pretty;
}
.ssg-game-wrap,
.ssg-game-wrap * {
  box-sizing: border-box
}

.ssg-hero-head .ssg-highlight {
  color: #7CBE42;

}

.ssg-yesno-btn.yes.selected {
  background: #00C058;
  box-shadow: inset 0 0 0 2px #9dd59d;
  color: #fff;
}

.ssg-vs-card.selected .ssg-vs-footer.light {
  background: #0f2b73;
  color: #fff;
}

.ssg-game-wrap {
  font-family: Arial, Helvetica, sans-serif;
  color: var(--ssg-white);
  position: relative;
  min-height: 900px;
  overflow: hidden;
  background: #071323
}

.ssg-step {
  display: none;
  min-height: 900px;
  background-size: cover;
  background-position: center;
  padding: 38px 40px 48px;
  position: relative
}

.ssg-step.active {
  display: block
}

.ssg-inline-helper {
  margin-top: 6px;
  font-size: 12px;
  color: #6b7280;
}

.ssg-overlay-screen {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 30;
  padding: 20px;
  background:
    linear-gradient(rgba(5, 20, 44, 0.78), rgba(8, 24, 34, 0.82)),
    radial-gradient(circle at top, rgba(69, 170, 242, 0.16), transparent 38%),
    radial-gradient(circle at bottom, rgba(34, 197, 94, 0.10), transparent 42%);
  backdrop-filter: blur(2px);
}

.ssg-overlay-screen.active {
  display: flex
}

.ssg-overlay-card {
  width: 420px;
  max-width: 90%;
  background: #fff;
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .10);
  text-align: center;
}

.ssg-overlay-card h2 {
  margin: 0 0 16px;
  font-family: Poppins, Inter, Arial, sans-serif;
  font-size: 32px;
  line-height: 40px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #111111;
}

.ssg-overlay-divider {
  height: 1px;
  background: #E5E7EB;
  margin: 0 0 16px;
}

.ssg-overlay-card p {
  margin: 0 0 24px;
  font-size: 14px;
  line-height: 20px;
  color: #666666;
}

.ssg-code-input {
  width: 100%;
  height: 48px;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 14px;
  border: 1px solid #D1D5DB;
  background: #F9FAFB;
  color: #111827;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.ssg-code-input::placeholder {
  color: #9CA3AF;
}

.ssg-code-input:focus {
  border-color: #6366F1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, .10);
}

.ssg-code-input.valid {
  border-color: #22C55E;
  background: #F0FDF4;
}

.ssg-code-input.invalid {
  border-color: #EF4444;
  background: #FEF2F2;
  animation: ssgShake .3s ease;
}

.ssg-overlay-submit {
  width: 100%;
  height: 48px;
  margin-top: 18px;
  border: 0;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 600;
  background: #E5E7EB;
  color: #9CA3AF;
  cursor: not-allowed;
  transition: all .2s ease;
}

.ssg-overlay-submit.enabled {
  background: #111111;
  color: #FFFFFF;
  cursor: pointer;
}

.ssg-overlay-submit.enabled:hover {
  background: #000000;
}

.ssg-overlay-submit.enabled:active {
  transform: scale(.98);
}

.ssg-field-group {
  margin-bottom: 16px;
}

.ssg-inline-error {
  min-height: 18px;
  margin-top: 6px;
  font-size: 12px;
  line-height: 16px;
  color: #EF4444;
  text-align: left;
}


.ssg-otp-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  flex-wrap: wrap;
}

/* OTP inline layout */

.ssg-inline-field {
  display: flex;
  gap: 10px;
  align-items: center;
  flex: 100%;
}

.ssg-inline-field .ssg-input {
  flex: 1;
}

.ssg-inline-field button {
  height: 46px;
  padding: 0 18px;
  border: none;
  background: #e31e24;
  color: #fff;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}

.ssg-inline-field button:hover {
  background: #c9141b;
}


.ssg-otp-trigger,
.ssg-otp-verify {
  appearance: none;
  border: 0;
  border-radius: 10px;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all .2s ease;
}

.ssg-otp-trigger {
  background: #ef1d24;
  color: #fff;
}

.ssg-otp-trigger:disabled,
.ssg-otp-verify:disabled {
  opacity: .7;
  cursor: not-allowed;
}

.ssg-otp-box {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 10px;
}

.ssg-otp-input {
  flex: 1 1 auto;
}

.ssg-otp-verify {
  background: #00C058;
  color: #fff;
  min-width: 120px;
}

.ssg-otp-verify.is-verified {
  background: #1f9d55;
}

.ssg-otp-status {
  font-size: 12px;
  line-height: 16px;
}

.ssg-otp-status.success {
  color: #16a34a;
}

.ssg-otp-status.error {
  color: #ef4444;
}

.ssg-otp-status.info {
  color: #1d4ed8;
}

.ssg-details-form.locked {
  opacity: .35;
  pointer-events: none;
  filter: blur(1px);
}

.ssg-input {
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.ssg-input.valid {
  border-color: #22C55E;
  background: #F0FDF4;
}

.ssg-input.invalid {
  border-color: #EF4444;
  background: #FEF2F2;
}

.ssg-input:focus {
  border-color: #6366F1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, .10);
  outline: none;
}

@keyframes ssgShake {

  0%,
  100% {
    transform: translateX(0)
  }

  20% {
    transform: translateX(-4px)
  }

  40% {
    transform: translateX(4px)
  }

  60% {
    transform: translateX(-3px)
  }

  80% {
    transform: translateX(3px)
  }
}

.ssg-step1-shell {
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
  min-height: 780px
}

.ssg-hero-head {
  text-align: center;
  padding-top: 10px
}

.ssg-hero-head h1 {
  font-size: 40px;
  line-height: 1.02;
  margin: 0 0 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto
}

.ssg-hero-head h1 .accent,
.ssg-game-wrap .accent {
  color: #86d329
}

.ssg-hero-head p {
  font-size: 23px;
  letter-spacing: 1px;
  margin: 0 auto;
  max-width: 880px
}

.ssg-form-card {
  width: 515px;
  max-width: 100%;
  background: #d9d9dc;
  color: #555;
  padding: 20px 20px 28px;
  border-radius: 8px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, .32);
  margin: 30px auto 0;
  position: relative
}

.ssg-form-card label {
  display: block;
  font-size: 16px;
  line-height: 1.2;
  margin: 16px 0 8px;
  color: #4f5358;
  font-weight: 700;
  letter-spacing: .3px
}

.ssg-form-card label:first-child {
  font-size: 16px;
  color: #555
}

.ssg-form-card label span {
  color: #ef1d24
}

.ssg-input {
  width: 100%;
  height: 40px;
  border: 1px solid #f1d74c;
  background: #fff;
  padding: 0 14px;
  font-size: 16px;
  border-radius: 2px
}

.ssg-step-indicator strong.ssg-q2-title {
  max-width: calc(100% - 200px);
}

.ssg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  min-width: 210px;
  padding: 0 24px;
  border: 0;
  border-radius: 4px;
  background: var(--ssg-red);
  color: #fff;
  font-weight: 800;
  letter-spacing: .5px;
  font-size: 18px;
  cursor: pointer;
  text-transform: uppercase;
  box-shadow: none
}

.ssg-btn:hover {
  opacity: .94
}

.ssg-btn:disabled {
  opacity: .55;
  cursor: not-allowed
}

.ssg-next-step {
  width: 100%;
  margin-top: 28px
}

.ssg-error {
  margin-top: 14px;
  color: #ff0000;
  font-size: 15px;
  min-height: 18px;
  text-align: center
}

.ssg-stage-head {
  text-align: center;
  max-width: 1240px;
  margin: 0 auto 20px;
  position: relative
}

.ssg-welcome-line,
.ssg-picked-line {
  font-size: 18px;
  font-weight: 800;
  color: #f4c913;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px
}

.ssg-step-indicator {
  display: flex;
  justify-content: center;
  gap: 14px;
  font-size: 25px;
  line-height: 1.15;
  text-transform: uppercase;
  font-weight: 400;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: baseline;
}

.ssg-step-indicator span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: #135ab0;
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  border-radius: 2px
}

.ssg-step-indicator strong {
  font-weight: 400;
  flex: 0 0 70%;
}

.ssg-helper {
  font-size: 18px;
  letter-spacing: 2px;
  margin-top: 12px;
  color: #fff;
  opacity: .95
}

.ssg-floating-ball {
  position: absolute;
  right: 80px;
  top: 10px;
  width: auto;
  height: auto
}

.ssg-quote {
  margin: 20px auto 0;
  background: rgba(100, 100, 100, .66);
  display: table;
  padding: 10px 20px;
  font-size: 17px;
  letter-spacing: 2px;
  text-align: center;
  max-width: 90%
}

.ssg-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 28px;
  align-items: center
}

.ssg-actions.dual {
  gap: 14px
}

.ssg-btn-secondary {
  background: #7d7d7d
}

.ssg-option-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  max-width: 1270px;
  margin: 34px auto 0
}

.ssg-option-card {
  background: transparent;
  cursor: pointer;
  transition: transform .22s ease, box-shadow .22s ease;
  position: relative
}

.ssg-option-card:hover {
  transform: translateY(-3px)
}

.ssg-option-card.selected {
  transform: translateY(-4px)
}

.ssg-option-media {
  background: rgba(255, 255, 255, .14);
  height: 430px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .35)
}

.ssg-option-media img.main {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block
}

.ssg-option-card.player .ssg-option-media img.main {
  object-fit: contain;
  object-position: center bottom;
  background: rgba(255, 255, 255, .06)
}

.ssg-option-footer {
  background: #efefef;
  min-height: 135px;
  color: #171d28;
  text-align: center;
  padding: 14px 12px 18px;
  border-radius: 0 0 10px 10px
}

.ssg-option-card.selected .ssg-option-footer {
  background: var(--ssg-blue);
  color: #fff
}

.ssg-option-icon {
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 6px
}

.ssg-option-icon img {
  max-width: 56px;
  max-height: 56px
}

.ssg-option-label {
  font-size: 28px;
  font-weight: 400;
  line-height: 1.1;
  text-transform: uppercase
}

.ssg-option-subtitle {
  font-size: 18px;
  opacity: .55;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 6px
}

.ssg-option-card.selected .ssg-option-subtitle {
  opacity: .8;
  color: #fff
}

.ssg-checkmark {
  position: absolute;
  left: 20px;
  top: 20px;
  width: 50px;
  height: 50px;
  background: #135ab0;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  color: #fff;
  font-weight: 700;
  z-index: 2
}

.ssg-option-card.selected .ssg-checkmark {
  display: flex
}

.ssg-yesno-wrap {
  max-width: 520px;
  margin: 34px auto 0;
}

.ssg-yesno-focus {
  width: 100%;
  max-width: 340px;
  margin: 0 auto;
  background: #efefef;
  color: #161d2a;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
}

.ssg-yesno-focus-media {
  height: 300px;
  background: rgba(255, 255, 255, .14);
  border: 1px solid rgba(255, 255, 255, .28);
  position: relative;
  overflow: hidden;
}

.ssg-yesno-focus-media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(255, 255, 255, .15), rgba(255, 255, 255, .15));
}

.ssg-yesno-focus-media .bg {
  position: absolute;
  inset: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  opacity: .25;
}

.ssg-yesno-focus-media .fg {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: auto;
  max-width: 74%;
  max-height: 92%;
  object-fit: contain;
  z-index: 1;
  mix-blend-mode: multiply;
}

.ssg-yesno-footer {
  padding: 14px 14px 16px;
  text-align: center;
  background: #efefef;
  border-top: 2px solid #d7c857;
}

.ssg-yesno-footer .ssg-option-icon {
  height: 34px;
  margin-bottom: 4px;
}

.ssg-yesno-footer .ssg-option-icon img {
  max-width: 34px;
  max-height: 34px;
}

.ssg-yesno-footer .ssg-option-label {
  font-size: 22px;
  line-height: 1.1;
  font-weight: 400;
  text-transform: uppercase;
}

.ssg-yesno-footer .ssg-option-subtitle {
  font-size: 13px;
  opacity: .55;
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-top: 6px;
}

.ssg-yesno-buttons {
  max-width: 340px;
  margin: 14px auto 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.ssg-yesno-btn {
  height: 78px;
  border-radius: 2px;
  border: 0;
  font-size: 19px;
  font-weight: 800;
  letter-spacing: .5px;
  cursor: pointer;
  text-transform: uppercase;
  box-shadow: none;
}

.ssg-yesno-btn.yes {
  background: #e5e7eb;
  color: #6b7280;
}

.ssg-yesno-btn.no {
  background: #e5e7eb;
  color: #6b7280;
}

.ssg-yesno-btn.yes.selected {
  background: #00C058;
  box-shadow: inset 0 0 0 2px #9dd59d;
  color: #fff;
}

.ssg-yesno-btn.no.selected {
  background: #D3311F;
  box-shadow: inset 0 0 0 2px #ef6b6b;
  color: #fff;
}

.ssg-confirm-card {
  max-width: 560px;
  margin: 120px auto 0;
  background: rgba(90, 90, 90, .35);
  padding: 36px 44px 40px;
  border-radius: 8px;
  text-align: center;
  backdrop-filter: blur(5px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, .28)
}

.ssg-confirm-check img {
  width: 90px;
  height: 90px
}

.ssg-confirm-card h2 {
  font-size: 36px;
  line-height: 1.1;
  font-weight: 400;
  letter-spacing: 1px;
  margin: 16px 0 18px;
  text-transform: uppercase
}

.ssg-confirm-line {
  font-size: 20px;
  line-height: 1.6;
  margin: 0 0 24px
}

.ssg-confirm-line strong,
.ssg-confirm-line .accent-red {
  color: #ff2d2d
}

.ssg-reward-box {
  background: var(--ssg-blue);
  padding: 28px 22px;
  border-radius: 4px
}

.ssg-reward-box h3 {
  font-size: 19px;
  letter-spacing: 1px;
  margin: 0 0 12px;
  text-transform: uppercase
}

.ssg-reward-box p {
  margin: 0 0 10px;
  font-size: 17px;
  line-height: 1.55
}

.ssg-entry-ref {
  display: block;
  color: #d8e4ff;
  font-size: 13px;
  letter-spacing: 1px;
  text-transform: uppercase
}

.ssg-closed-box,
.ssg-leaderboard {
  background: #08192d;
  color: #fff;
  padding: 24px;
  border-radius: 8px
}

.ssg-leaderboard table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 16px
}

.ssg-leaderboard th,
.ssg-leaderboard td {
  border-bottom: 1px solid rgba(255, 255, 255, .12);
  padding: 12px 10px;
  text-align: left
}

/* admin */
.ssg-admin-wrap .ssg-admin-card {
  background: #fff;
  border: 1px solid #dde1e7;
  border-radius: 10px;
  padding: 18px 20px;
  box-shadow: 0 8px 24px rgba(17, 24, 39, .04)
}

.ssg-admin-topbar {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 16px;
  margin: 18px 0
}

.ssg-admin-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 18px;
  align-items: start
}

.ssg-game-list {
  margin: 14px 0 0;
  padding: 0;
  list-style: none
}

.ssg-game-list li {
  margin-bottom: 8px
}

.ssg-game-list li a {
  display: block;
  padding: 12px;
  border-radius: 8px;
  text-decoration: none;
  color: #101828;
  background: #f8fafc;
  border: 1px solid #e6ebf2
}

.ssg-game-list li.active a {
  background: #eaf2ff;
  border-color: #a7c5ff
}

.ssg-game-list span {
  display: block;
  margin-top: 6px;
  color: #667085;
  font-size: 12px
}

.ssg-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 16px
}

.ssg-field-grid p,
.ssg-yesno-fields p {
  margin: 0
}

.ssg-field-grid label,
.ssg-admin-question-box label,
.ssg-yesno-fields label {
  display: block;
  font-weight: 600;
  margin-bottom: 6px
}

.ssg-field-grid input[type="text"],
.ssg-field-grid input[type="url"],
.ssg-field-grid input[type="datetime-local"],
.ssg-field-grid select,
.ssg-yesno-fields input,
.ssg-options-editor input,
.ssg-admin-card textarea {
  width: 100%
}

.ssg-checkbox-pair {
  padding-top: 28px
}

.ssg-admin-question-box {
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  padding: 18px;
  margin-top: 18px;
  background: #fbfdff
}

.ssg-yesno-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 16px;
  margin-top: 10px
}

.ssg-options-editor input[type="text"],
.ssg-options-editor input[type="url"],
.ssg-options-editor input[type="number"] {
  width: 100%;
  min-width: 120px
}

.ssg-admin-actions-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  margin-bottom: 12px;
  flex-wrap: wrap
}

.ssg-entries-table small {
  color: #667085
}

.ssg-toggle-line {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600
}

.ssg-actions.single {
  justify-content: center;
  margin-top: 24px;
}

.ssg-actions.single .ssg-btn {
  width: 100%;
  max-width: 340px;
}

p.ssg-repeat-copy {
  color: orange;
}

.ssg-confirm-card-v2 {
  max-width: 720px;
  margin: 100px auto 0;
  background: rgba(90, 90, 90, .28);
  padding: 34px 42px 36px;
  border-radius: 10px;
  text-align: center;
  backdrop-filter: blur(22px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, .28);
}

.ssg-confirm-card-v2 .ssg-confirm-check img {
  width: 92px;
  height: 92px;
}

.ssg-confirm-card-v2 h2 {
  font-size: 38px;
  line-height: 1.1;
  font-weight: 400;
  letter-spacing: 1px;
  margin: 18px 0 26px;
  text-transform: uppercase;
}

.ssg-confirm-picks {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin: 0 auto 28px;
  flex-wrap: wrap;
}

.ssg-confirm-pick-card {
  width: 190px;
  min-height: 118px;
  background: rgba(20, 20, 20, .72);
  border-radius: 18px;
  padding: 12px 14px 14px;
  text-align: center;
  color: #fff;
}

.ssg-confirm-pick-img {
  height: 34px;
  margin-bottom: 8px;
}

.ssg-confirm-pick-img img {
  max-height: 34px;
  max-width: 48px;
  object-fit: contain;
}

.ssg-confirm-pick-text {
  font-size: 16px;
  line-height: 1.35;
  color: #f3f4f6;
}

.ssg-confirm-pick-text .accent-red {
  color: #ff2d2d;
  font-weight: 700;
}

.ssg-confirm-card-v2 .ssg-reward-box {
  max-width: 400px;
  margin: 0 auto;
  background: #0057b8;
  border: 2px solid rgba(255, 255, 255, .75);
  border-radius: 8px;
  padding: 24px 18px;
}

.ssg-confirm-card-v2 .ssg-reward-box h3 {
  margin: 0 0 10px;
  font-size: 20px;
  color: #fff;
  letter-spacing: .5px;
}

.ssg-confirm-card-v2 .ssg-reward-box p {
  margin: 0;
  font-size: 14px;
  line-height: 1.65;
  color: #eaf2ff;
}

.ssg-confirm-vs-picks {
  margin: 0 auto 28px;
  max-width: 780px;
}

.ssg-confirm-vs-grid {
  display: grid;
  grid-template-columns: 1fr 86px 1fr;
  gap: 14px;
  align-items: center;
}

.ssg-confirm-vs-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ssg-confirm-vs-center img {
  width: 72px;
  height: 72px;
  object-fit: contain;
}

.ssg-confirm-vs-card {
  background: rgba(20, 20, 20, .75);
  border-radius: 18px;
  overflow: hidden;
  color: #fff;
  min-height: 220px;
}

.ssg-confirm-vs-media {
  height: 140px;
  position: relative;
  background: rgba(255, 255, 255, .06);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  overflow: hidden;
}

.ssg-confirm-vs-media img {
  max-width: 72%;
  max-height: 92%;
  object-fit: contain;
}

.ssg-confirm-vs-footer {
  padding: 16px 16px 18px;
  text-align: left;
}

.ssg-confirm-vs-name-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.ssg-confirm-vs-name {
  font-size: 19px;
  line-height: 1.15;
  font-weight: 600;
  text-transform: uppercase;
}

.ssg-confirm-vs-mini-icon {
  width: 32px;
  height: 32px;
  object-fit: contain;
  flex: 0 0 auto;
}

.ssg-confirm-vs-value {
  margin-top: 10px;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
  color: #ffdf5a;
}

.ssg-confirm-vs-subtitle {
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.25;
  text-transform: uppercase;
  opacity: .82;
  letter-spacing: .4px;
}

.ssg-inline-error {
  min-height: 18px;
  margin: 6px 0 12px;
  font-size: 12px;
  line-height: 16px;
  color: #dc2626;
}

.ssg-input {
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.ssg-input.valid {
  border-color: #22c55e;
  background: #f0fdf4;
}

.ssg-input.invalid {
  border-color: #ef4444;
  background: #fef2f2;
}

.ssg-input:focus {
  outline: none;
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99, 102, 241, .12);
}

@media (max-width: 1200px) {
  .ssg-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr))
  }

  .ssg-hero-head h1 {
    font-size: 56px
  }

  .ssg-admin-layout {
    grid-template-columns: 1fr
  }

  .ssg-admin-topbar {
    grid-template-columns: 1fr
  }
}

@media (max-width: 820px) {
  .ssg-step {
    padding: 24px 16px 34px;
    min-height: 100vh
  }

  .ssg-overlay-card {
    padding: 20px;
    width: 90%;
  }

  .ssg-overlay-card h2 {
    font-size: 24px;
    line-height: 32px;
  }

  .ssg-form-card {
    width: 90%;
    padding: 20px;
    margin-top: 28px;
  }

  .ssg-step1-shell {
    min-height: auto
  }

  .ssg-hero-head h1 {
    font-size: 20px
  }

  .ssg-hero-head p {
    font-size: 18px
  }

  .ssg-form-card {
    margin-top: 42px;
    padding: 22px 16px
  }

  .ssg-stage-head {
    margin-bottom: 14px
  }

  .ssg-step-indicator {
    font-size: 16px;
    gap: 10px
  }

  .ssg-step-indicator strong {
    max-width: 90%;
    display: block
  }

  .ssg-helper {
    font-size: 14px;
    letter-spacing: 1px
  }

  .ssg-option-grid {
    grid-template-columns: 1fr;
    gap: 18px
  }

  .ssg-option-media {
    height: 320px
  }

  .ssg-option-label {
    font-size: 24px
  }

  .ssg-floating-ball {
    right: 10px;
    top: 0;
    width: 32px
  }

  .ssg-actions.dual {
    flex-direction: column-reverse
  }

  .ssg-btn,
  .ssg-actions .ssg-btn {
    width: 100%;
    max-width: 420px
  }

  .ssg-quote {
    font-size: 13px;
    letter-spacing: 1px;
    max-width: 100%
  }

  .ssg-confirm-card {
    margin-top: 60px;
    padding: 24px 16px
  }

  .ssg-confirm-card h2 {
    font-size: 28px
  }

  .ssg-confirm-line {
    font-size: 18px
  }

  .ssg-field-grid,
  .ssg-yesno-fields {
    grid-template-columns: 1fr
  }
}

@media (max-width: 820px) {
  .ssg-yesno-wrap {
    max-width: 334px;
    margin-top: 22px
  }

  .ssg-yesno-focus {
    max-width: 334px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 12px 28px rgba(0, 0, 0, .25)
  }

  .ssg-yesno-focus-media {
    height: 105px;
    border: 0;
    border-right: 1px solid rgba(0, 0, 0, .06)
  }

  .ssg-yesno-focus-media .bg {
    opacity: .44
  }

  .ssg-yesno-focus-media .fg {
    max-width: 82%;
    max-height: 95%;
    bottom: 0
  }

  .ssg-yesno-focus-media::after {
    background: linear-gradient(rgba(255, 255, 255, .08), rgba(255, 255, 255, .08))
  }

  .ssg-yesno-footer {
    min-height: 105px;
    padding: 10px 12px;
    border-top: 0;
    text-align: center;
    border-left: 1px solid rgba(0, 0, 0, .04)
  }

  .ssg-yesno-footer .ssg-option-icon {
    height: 28px;
    margin-bottom: 2px
  }

  .ssg-yesno-footer .ssg-option-icon img {
    max-width: 34px;
    max-height: 34px
  }

  .ssg-yesno-footer .ssg-option-label {
    font-size: 13px;
    line-height: 1.15
  }

  .ssg-yesno-footer .ssg-option-subtitle {
    font-size: 11px;
    letter-spacing: .8px;
    margin-top: 6px
  }

  .ssg-yesno-buttons {
    max-width: 334px;
    gap: 12px;
    margin-top: 18px
  }

  .ssg-yesno-btn {
    height: 84px;
    font-size: 18px;
    border-radius: 10px
  }

  .ssg-yesno-wrap {
    max-width: 360px;
    margin-top: 20px;
  }

  .ssg-yesno-focus {
    max-width: 330px;
  }

  .ssg-yesno-focus-media {
    height: 106px;
  }

  .ssg-yesno-focus-media .fg {
    max-width: 52%;
    max-height: 95%;
    left: 28%;
    bottom: 0;
    transform: translateX(-50%);
  }

  .ssg-yesno-footer {
    position: absolute;
    right: 0;
    top: 0;
    width: 50%;
    height: 100%;
    padding: 14px 10px;
    border-top: 0;
    border-left: 1px solid rgba(0, 0, 0, .08);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: #efefef;
  }

  .ssg-yesno-focus {
    position: relative;
    overflow: hidden;
  }

  .ssg-yesno-buttons {
    max-width: 330px;
    margin-top: 14px;
    gap: 12px;
  }

  .ssg-yesno-btn {
    height: 84px;
    font-size: 17px;
  }

  .ssg-yesno-footer .ssg-option-label {
    font-size: 14px;
  }

  .ssg-yesno-footer .ssg-option-subtitle {
    font-size: 10px;
  }

  .ssg-yesno-footer .ssg-option-icon img {
    max-width: 28px;
    max-height: 28px;
  }

  .ssg-confirm-card-v2 {
    max-width: 360px;
    margin: 56px auto 0;
    padding: 26px 18px 28px;
    border-radius: 8px;
  }

  .ssg-confirm-card-v2 .ssg-confirm-check img {
    width: 84px;
    height: 84px;
  }

  .ssg-confirm-card-v2 h2 {
    font-size: 26px;
    margin: 16px 0 22px;
  }

  .ssg-confirm-picks {
    gap: 10px;
    margin-bottom: 22px;
  }


  .ssg-confirm-pick-card {
    width: calc(50% - 6px);
    min-height: 120px;
    border-radius: 16px;
    padding: 10px 10px 12px;
  }

  .ssg-confirm-pick-text {
    font-size: 13px;
    line-height: 1.35;
  }

  .ssg-confirm-card-v2 .ssg-reward-box {
    max-width: 100%;
    padding: 18px 14px;
  }

  .ssg-confirm-card-v2 .ssg-reward-box h3 {
    font-size: 18px;
  }

  .ssg-confirm-card-v2 .ssg-reward-box p {
    font-size: 13px;
  }
}

.ssg-vs-wrap {
  max-width: 1080px;
  margin: 28px auto 0
}

.ssg-vs-grid {
  display: grid;
  grid-template-columns: 1fr 86px 1fr;
  gap: 18px;
  align-items: center
}

.ssg-vs-center {
  display: flex;
  align-items: center;
  justify-content: center
}

.ssg-vs-center img {
  width: 74px;
  height: 74px;
  object-fit: contain
}

.ssg-vs-card {
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease
}

.ssg-vs-card.selected {
  transform: translateY(-3px)
}

.ssg-vs-card.selected .ssg-vs-media,
.ssg-vs-card.selected .ssg-vs-footer {
  box-shadow: 0 0 0 3px rgba(255, 255, 255, .22)
}

.ssg-vs-media {
  position: relative;
  height: 365px;
  overflow: hidden;
  background: #dbe3ef
}

.ssg-vs-media .bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .28
}

.ssg-vs-media .fg {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  max-width: 72%;
  max-height: 94%;
  object-fit: contain
}

.ssg-vs-footer {
  min-height: 150px;
  padding: 18px 24px 16px
}

.ssg-vs-footer.blue {
  background: #0f2b73;
  color: #fff
}

.ssg-vs-footer.light {
  background: #f3f3f3;
  color: #111827
}

.ssg-vs-topline {
  font-size: 13px;
  line-height: 1;
  text-transform: uppercase;
  opacity: .8;
  margin-bottom: 10px
}

.ssg-vs-name-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px
}

.ssg-vs-name {
  font-size: 22px;
  line-height: 1.1;
  font-weight: 500;
  text-transform: uppercase
}

.ssg-vs-small-icon {
  width: 42px;
  height: 42px;
  object-fit: contain
}

.ssg-vs-value {
  margin-top: 10px;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase
}

.ssg-vs-subtitle {
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.2;
  letter-spacing: .4px;
  text-transform: uppercase;
  opacity: .78
}

@media (max-width: 820px) {
  .ssg-vs-wrap {
    max-width: 360px;
    margin-top: 18px
  }

  .ssg-vs-grid {
    grid-template-columns: 1fr;
    gap: 12px
  }

  .ssg-vs-center {
    order: 2
  }

  .ssg-vs-card.left {
    order: 1
  }

  .ssg-vs-card.right {
    order: 3
  }

  .ssg-vs-center img {
    width: 58px;
    height: 58px
  }

  .ssg-vs-media {
    height: 220px
  }

  .ssg-vs-footer {
    min-height: auto;
    padding: 14px 16px
  }

  .ssg-vs-name {
    font-size: 18px
  }

  .ssg-vs-value {
    font-size: 16px
  }

  .ssg-vs-subtitle {
    font-size: 12px
  }

  .ssg-confirm-vs-picks {
    max-width: 100%;
    margin-bottom: 22px;
  }

  .ssg-confirm-vs-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .ssg-confirm-vs-center img {
    width: 54px;
    height: 54px;
  }

  .ssg-confirm-vs-card {
    min-height: auto;
  }

  .ssg-confirm-vs-media {
    height: 110px;
  }

  .ssg-confirm-vs-name {
    font-size: 16px;
  }

  .ssg-confirm-vs-value {
    font-size: 14px;
  }

  .ssg-confirm-vs-subtitle {
    font-size: 11px;
  }
}

@media (max-width: 640px) {
  .ssg-otp-box {
    flex-direction: column;
    align-items: stretch;
  }
    .ssg-inline-field{
          display: flex;
            gap: 10px;
            align-items: center;
            flex: 100%;
            flex-direction: row;
            flex-wrap: wrap;
    }
.ssg-input{
  padding: 14px 14px;
}
  .ssg-otp-verify,
  .ssg-otp-trigger {
    width: 100%;
  }
}