.register-page-body {
  /* Consistent highlight for required fields, focus, selection, and validation */
  --register-highlight: var(--neon-500);
  --register-highlight-shadow: 0 0 12px rgba(22, 223, 253, 0.55), 0 0 28px rgba(22, 223, 253, 0.35);
  color: #f4f3ff;
  font-family: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

.register-decorations .decoration {
  pointer-events: none;
}

.register-main {
  padding-bottom: 80px;
}

.register-hero {
  padding: 120px 0 0;
}

.register-hero-card {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.register-title {
  font-family: 'Urbanist', system-ui, sans-serif;
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.03em;
  margin-bottom: 32px;
}

.register-hero-subtitle {
  margin-top: 12px;
  text-align: center;
}

.register-hero-subtitle:not(.is-visible) {
  display: none;
}

.register-hero-subtitle.is-visible {
  display: block;
}

.register-hero-subtitle-title {
  font-family: 'Urbanist', sans-serif;
  font-weight: 700;
  font-size: 33px;
  line-height: 45px;
  color: var(--text-primary);
  margin: 0 0 8px;
}

.register-hero-subtitle-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 17px;
  line-height: 24px;
  color: var(--text-primary);
}

.register-subtitle {
  font-size: 15px;
  color: rgba(244, 243, 255, 0.8);
}

.register-section {
  padding: 0 0 64px;
}

.register-card {
  max-width: 900px;
  margin: 0 auto;
  padding: 40px 24px 28px;
  border-radius: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.register-steps-header {
  --register-steps-count: 4;
  --register-step-progress: 0;
  --register-step-line-inset: calc(100% / (var(--register-steps-count) * 2));
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 26px;
  position: relative;
  width: 100%;
}

.register-steps-header::before,
.register-steps-header::after {
  content: '';
  position: absolute;
  top: 11px;
  left: var(--register-step-line-inset);
  right: var(--register-step-line-inset);
  height: 2px;
  border-radius: 8px;
  pointer-events: none;
}

.register-steps-header::before {
  background: #2a364b;
}

.register-steps-header::after {
  right: auto;
  width: calc((100% - (var(--register-step-line-inset) * 2)) * var(--register-step-progress) / 100);
  background: var(--neon-500);
  transition: width 0.22s ease-out;
}

.register-step-indicator {
  display: flex;
  flex: 1 0 0;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  position: relative;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  text-align: center;
  cursor: pointer;
  z-index: 1;
  transition: color 0.18s ease-out;
}

.register-step-indicator:hover {
  color: var(--text-primary);
}

.register-steps-locked .register-step-indicator {
  pointer-events: none;
  cursor: default;
}

.register-step-marker {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 4px solid #2a364b;
  background: #0f1f38;
  position: relative;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: border-color 0.18s ease-out, background-color 0.18s ease-out;
}

.register-step-number {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 11px;
  line-height: 1;
  color: #0f1f38;
  opacity: 0;
}

.register-step-text {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.register-step-label {
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 24px;
  color: var(--text-secondary);
}

.register-step-help {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 12px;
  line-height: 18px;
  color: var(--text-secondary);
}

.register-step-current {
  color: var(--text-primary);
}

.register-step-current .register-step-label {
  color: var(--neon-500);
}

.register-step-current .register-step-marker {
  border-color: var(--neon-500);
  background: #0f1f38;
}

.register-step-current .register-step-number {
  opacity: 1;
}

.register-step-completed {
  color: var(--text-primary);
}

.register-step-completed .register-step-label {
  color: var(--text-primary);
}

.register-step-completed .register-step-marker {
  border-color: var(--neon-500);
  background: var(--neon-500);
}

.register-step-completed .register-step-number {
  opacity: 0;
}

.register-step-completed .register-step-marker::after {
  content: '';
  position: absolute;
  width: 7px;
  height: 11px;
  border-right: 2px solid #0f1f38;
  border-bottom: 2px solid #0f1f38;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -58%) rotate(45deg);
}

.register-alert {
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  margin-bottom: 16px;
}

.register-alert-success {
  border: 1px solid rgba(74, 222, 128, 0.6);
  background: linear-gradient(135deg, rgba(15, 118, 110, 0.8), rgba(22, 163, 74, 0.8));
}

.register-alert-warning {
  border: 1px solid rgba(248, 250, 109, 0.6);
  background: linear-gradient(135deg, rgba(120, 53, 15, 0.85), rgba(133, 77, 14, 0.9));
}

.register-form {
  margin-top: 6px;
  position: relative;
}

.register-step {
  display: none;
}

/* Step 1 visible by default so event type cards show even if JS fails to run */
.register-step[data-step="1"] {
  display: block;
}

.register-step-title {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 16px;
}

.register-step-description {
  font-size: 13px;
  color: rgba(244, 243, 255, 0.72);
  margin-bottom: 14px;
}

.register-type-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.register-type-card {
  border-radius: 16px;
  padding: 18px 16px;
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  border: 1px solid var(--alfa-grey-1);
  cursor: pointer;
  text-align: left;
  transition:
    border-color 0.2s ease-out,
    box-shadow 0.2s ease-out;
}

.register-type-card:hover,
.register-type-card-selected {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

.register-type-kicker {
  display: block;
  margin-bottom: 8px;
  font-family: 'Urbanist', sans-serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 30px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-primary);
}

.register-type-title {
  font-size: 15px;
  font-weight: 500;
  margin-bottom: 2px;
}

.register-type-text {
  display: block;
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
  color: var(--text-secondary);
}

.register-events-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

/* Single empty-state message must span both columns (otherwise it sits in column 1 only). */
.register-events-list > .register-empty {
  grid-column: 1 / -1;
  margin: 0;
}

.register-event-card {
  position: relative;
  border-radius: 16px;
  padding: 16px;
  text-align: left;
  overflow: hidden;
  isolation: isolate;
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  border: 1px solid var(--alfa-grey-1);
  cursor: pointer;
  transition:
    border-color 0.2s ease-out,
    box-shadow 0.2s ease-out;
}

.register-event-save-badge {
  position: absolute;
  top: 0;
  right: 0;
  width: 180px;
  padding: 8px 19px 8px 13px;
  font-size: 11px;
  font-weight: 700;
  color: white;
  background-color: var(--bg-brand-dark);
  border: none;
  box-shadow: inset 4px 5px 6px 0 #ff1597, inset -4px -5px 6px 0 #ff1597;
  transform: rotate(45deg) translate(32%, -32%) translate(-3px, -3px);
  transform-origin: center;
  text-align: center;
}

.register-event-cube-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  object-fit: contain;
}

.register-event-card:hover,
.register-event-card-selected {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

.register-event-card-not-opened {
  opacity: 0.85;
  cursor: default;
}

.register-event-card-not-opened:hover {
  border-color: var(--alfa-grey-1);
  box-shadow: none;
}

.register-event-card-not-opened.register-event-card-selected {
  border-color: rgba(248, 250, 109, 0.5);
  box-shadow: 0 0 12px rgba(248, 250, 109, 0.2);
}

.register-event-not-opened-badge {
  margin-top: 6px;
  padding: 4px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(248, 250, 109, 0.95);
  background: rgba(120, 53, 15, 0.4);
  border: 1px solid rgba(248, 250, 109, 0.4);
}

.register-event-title {
  font-family: 'Urbanist', sans-serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 30px;
  color: var(--text-primary);
  margin-bottom: 12px;
}

.register-event-meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.register-event-meta-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 20px;
  color: var(--text-primary);
}

.register-event-batch {
  align-items: flex-start;
}

.register-event-price {
  margin-top: 10px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--neon-500);
}

.register-event-meta-item-price span {
  color: var(--text-primary);
}

.icon-calendar-small,
.icon-location-small,
.icon-price-small {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  object-fit: contain;
  display: block;
}

.register-empty {
  font-size: 13px;
  color: rgba(241, 245, 249, 0.8);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px dashed rgba(148, 163, 253, 0.5);
  background: rgba(15, 23, 42, 0.8);
}

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

.register-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

fieldset.register-field {
  border: 0;
  padding: 0;
  margin: 0;
  min-inline-size: 0;
}

.register-field-full {
  grid-column: 1 / -1;
}

.register-field label,
.register-field legend {
  font-family: 'Urbanist', sans-serif;
  font-weight: 500;
  font-size: 18px;
  line-height: 40px;
  color: var(--text-primary);
}

/* Same style as dance role elements (Leader, Follower, Both) - 1.2x height */
.register-field input[type="text"],
.register-field input[type="email"],
.register-field textarea,
.register-field select {
  border-radius: 16px;
  border: 2px solid var(--alfa-grey-2);
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  padding: 10px 17px;
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 24px;
  color: var(--text-primary);
  outline: none;
  transition:
    border-color 0.12s ease-out,
    box-shadow 0.12s ease-out,
    background 0.12s ease-out;
}

.register-field input:focus,
.register-field textarea:focus,
.register-field select:focus {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
}

/* Ticket/package dropdown: dark background instead of white */
.register-field select option {
  background: #121e36;
  color: var(--text-primary);
}

.register-field select option:checked,
.register-field select option:hover {
  background: #2a364b;
}

/* Keep ticket type chevron fixed on the right side */
#ticket_type {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 48px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.25L6 6.25L11 1.25' stroke='%23f4f3ff' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 17px center;
  background-size: 12px 8px;
}

#ticket_type::-ms-expand {
  display: none;
}

/* Same background as autofill when user has entered text */
.register-field input[type="text"]:not(:placeholder-shown),
.register-field input[type="email"]:not(:placeholder-shown),
.register-field textarea:not(:placeholder-shown) {
  background: #121e36;
}

/* Ticket/package: same background as entered text when selected */
#ticket_type:valid {
  background-color: #121e36;
}

/* Override browser autofill white/yellow background to match dark theme */
.register-field input:is(:-webkit-autofill, :autofill),
.register-field input:is(:-webkit-autofill, :autofill):hover,
.register-field input:is(:-webkit-autofill, :autofill):focus,
.register-field input:is(:-webkit-autofill, :autofill):active,
.register-field textarea:is(:-webkit-autofill, :autofill),
.register-field textarea:is(:-webkit-autofill, :autofill):hover,
.register-field textarea:is(:-webkit-autofill, :autofill):focus,
.register-field textarea:is(:-webkit-autofill, :autofill):active {
  -webkit-text-fill-color: var(--text-primary);
  -webkit-box-shadow: 0 0 0 1000px #121e36 inset;
  box-shadow: 0 0 0 1000px #121e36 inset;
  transition: background-color 5000s ease-in-out 0s;
}

.register-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.register-option {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 16px;
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  border: 2px solid var(--alfa-grey-2);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 20px;
  color: var(--text-primary);
  cursor: pointer;
}

.register-option:hover,
.register-option:has(input:checked) {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

/* Payment method, dance role, experience years: use Figma radio pattern */
[data-validate="payment"] .register-options,
[data-validate="role"] .register-options,
[data-validate="experience"] .register-options {
  gap: 18px 24px;
}

[data-validate="payment"] .register-option,
[data-validate="role"] .register-option,
[data-validate="experience"] .register-option {
  padding: 8px 14px;
  border: 2px solid var(--alfa-grey-2);
  border-radius: 16px;
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  box-shadow: none;
  gap: 12px;
}

[data-validate="payment"] .register-option:hover,
[data-validate="payment"] .register-option:has(input:checked),
[data-validate="role"] .register-option:hover,
[data-validate="role"] .register-option:has(input:checked),
[data-validate="experience"] .register-option:hover,
[data-validate="experience"] .register-option:has(input:checked) {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

[data-validate="payment"] .register-option span,
[data-validate="role"] .register-option span,
[data-validate="experience"] .register-option span {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 24px;
  font-weight: 400;
  color: var(--text-primary);
}

[data-validate="payment"] .register-option input[type="radio"],
[data-validate="role"] .register-option input[type="radio"],
[data-validate="experience"] .register-option input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--register-highlight);
  background: #05122b;
  margin: 0;
  position: relative;
  cursor: pointer;
  transition: box-shadow 0.15s ease-out, border-color 0.15s ease-out, background 0.15s ease-out;
}

[data-validate="payment"] .register-option input[type="radio"]:hover,
[data-validate="role"] .register-option input[type="radio"]:hover,
[data-validate="experience"] .register-option input[type="radio"]:hover {
  box-shadow: 0 0 10px rgba(22, 223, 253, 0.35);
}

[data-validate="payment"] .register-option input[type="radio"]:checked,
[data-validate="role"] .register-option input[type="radio"]:checked,
[data-validate="experience"] .register-option input[type="radio"]:checked {
  background: radial-gradient(circle at center, #16dffd 0 6px, #05122b 6px 100%);
}

[data-validate="payment"] .register-option input[type="radio"]:focus-visible,
[data-validate="role"] .register-option input[type="radio"]:focus-visible,
[data-validate="experience"] .register-option input[type="radio"]:focus-visible {
  outline: none;
  box-shadow: var(--register-highlight-shadow);
}

.register-option input {
  accent-color: var(--register-highlight);
}

.register-options-compact .register-option-pill {
  padding-inline: 10px;
}

.register-hint {
  margin-top: 3px;
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 20px;
  color: var(--text-secondary);
}

.register-error {
  margin-top: 3px;
  font-size: 11px;
  color: #fed7d7;
}

.register-event-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.register-event-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 14px;
  border-radius: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  line-height: 20px;
  cursor: pointer;
  border: none;
  transition: background 0.15s ease-out, box-shadow 0.15s ease-out, border-color 0.15s ease-out;
}

.register-event-action-select {
  background: var(--neon-500);
  color: #0f1f38;
  border: 1px solid var(--neon-500);
}

.register-event-action-select:hover {
  background: transparent;
  color: var(--neon-500);
  box-shadow: 0 0 8px rgba(22, 223, 253, 0.4);
}

.register-event-action-notify {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--alfa-grey-2);
}

.register-event-action-notify:hover {
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

.register-hero-subtitle-notification {
  margin-top: 12px;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  line-height: 22px;
  color: rgba(248, 250, 109, 0.9);
  font-weight: 500;
}

.register-secret-code-status {
  margin-top: 4px;
  font-size: 13px;
  min-height: 1.4em;
}

.register-secret-code-status.is-valid {
  color: #68d391;
}

.register-secret-code-status.is-invalid {
  color: #fed7d7;
}

.register-secret-code-status.is-loading {
  color: var(--text-secondary);
  font-style: italic;
}

.register-error-full {
  grid-column: 1 / -1;
}

.register-captcha-row {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 4px 30px;
  align-items: flex-end;
  padding-bottom: 6px;
}

.register-captcha-block {
  display: contents;
}

.register-captcha-block label {
  grid-column: 1 / -1;
}

.register-captcha-block input {
  grid-column: 1;
  max-width: 200px;
  width: 200px;
}

.register-captcha-code {
  grid-column: 2;
  grid-row: 2;
  justify-self: start;
  align-self: flex-end;
  margin-top: -16px;
  padding: 0 0 2px 0;
  text-align: left;
  letter-spacing: 0.3em;
  font-family: 'Urbanist', system-ui, sans-serif;
  font-weight: 700;
  font-size: 25px;
  line-height: 1.2;
  color: var(--text-primary);
}

.register-terms {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  line-height: 1.4;
}

.register-terms input[type="checkbox"] {
  margin-top: 6px;
  width: 28px;
  height: 28px;
  min-width: 28px;
  min-height: 28px;
  flex-shrink: 0;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 16px;
  border: 2px solid var(--alfa-grey-2);
  background: radial-gradient(120% 120% at 50% 50%, #2a364b 0%, #121e36 100%);
  cursor: pointer;
  transition: border-color 0.12s ease-out, box-shadow 0.12s ease-out, background 0.12s ease-out;
}

.register-terms input[type="checkbox"]:focus {
  outline: none;
  border-color: var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
}

.register-terms input[type="checkbox"]:checked {
  border-color: #16dffd;
  box-shadow: none;
  background-color: #16dffd;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2305122b' stroke-width='2.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='19 7 10 16 5 11'%3E%3C/polyline%3E%3C/svg%3E");
  background-size: 22px 22px;
  background-position: center;
  background-repeat: no-repeat;
}

.register-terms a {
  color: var(--register-highlight);
  text-decoration: underline;
}

.register-terms-link {
  border: none;
  padding: 0;
  margin: 0;
  background: none;
  color: var(--register-highlight);
  text-decoration: underline;
  font: inherit;
  cursor: pointer;
}

.register-footer {
  margin-top: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.register-nav-btn {
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 9px 16px;
  font-family: 'Urbanist', sans-serif;
  font-size: 22px;
  line-height: 30px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition:
    background 0.15s ease-out,
    border-color 0.15s ease-out,
    box-shadow 0.15s ease-out;
}

.register-nav-back {
  background: transparent;
  color: var(--white-100);
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: color 0.3s, text-shadow 0.3s;
}

.register-nav-back-icon.icon-btn-icon,
.register-nav-next-icon.icon-btn-icon {
  width: 22px;
  height: 22px;
}

.register-nav-back-icon .icon-default,
.register-nav-back-icon .icon-pressed,
.register-nav-next-icon .icon-default,
.register-nav-next-icon .icon-pressed {
  object-fit: contain;
  opacity: 0.9;
  transition: filter 0.3s, opacity 0.3s;
}

.register-nav-next {
  margin-left: auto;
  background: transparent;
  color: var(--white-100);
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: color 0.3s, text-shadow 0.3s;
}

.register-nav-next:hover:not([disabled]):not(:disabled):not(.register-nav-next-disabled) {
  color: var(--white-100);
  text-shadow: 0 0 10px rgba(22, 223, 253, 0.85), 0 0 22px rgba(22, 223, 253, 0.6), 0 0 36px rgba(22, 223, 253, 0.4);
}

.register-nav-next:hover:not([disabled]):not(:disabled):not(.register-nav-next-disabled) .register-nav-next-icon {
  opacity: 1;
  filter: drop-shadow(0 0 6px rgba(22, 223, 253, 0.7)) drop-shadow(0 0 14px rgba(22, 223, 253, 0.45));
}

.register-nav-next:active:not([disabled]):not(:disabled):not(.register-nav-next-disabled) {
  color: var(--white-100);
  text-shadow: 0 0 10px rgba(22, 223, 253, 0.85), 0 0 22px rgba(22, 223, 253, 0.6), 0 0 36px rgba(22, 223, 253, 0.4);
}

.register-nav-next:active:not([disabled]):not(:disabled):not(.register-nav-next-disabled) .register-nav-next-icon {
  opacity: 1;
  filter: drop-shadow(0 0 6px rgba(22, 223, 253, 0.7)) drop-shadow(0 0 14px rgba(22, 223, 253, 0.45));
}

.register-nav-next[disabled],
.register-nav-next:disabled,
.register-nav-next.register-nav-next-disabled {
  opacity: 1;
  cursor: not-allowed;
  background: transparent;
  box-shadow: none;
  color: rgba(226, 232, 240, 0.5);
  text-shadow: none;
  pointer-events: none;
}

.register-nav-next[disabled] .register-nav-next-icon,
.register-nav-next:disabled .register-nav-next-icon {
  opacity: 0.45;
  filter: grayscale(1) brightness(0.8);
}

.register-nav-btn:hover:not([disabled]),
.register-submit-btn:not([disabled]):hover {
  box-shadow: 0 14px 38px rgba(0, 0, 0, 0.7);
}

.register-nav-back:hover:not([disabled]) {
  background: transparent;
  color: var(--white-100);
  text-shadow: 0 0 10px rgba(22, 223, 253, 0.85), 0 0 22px rgba(22, 223, 253, 0.6), 0 0 36px rgba(22, 223, 253, 0.4);
}

.register-nav-back:hover:not([disabled]) .register-nav-back-icon {
  opacity: 1;
  filter: drop-shadow(0 0 6px rgba(22, 223, 253, 0.7)) drop-shadow(0 0 14px rgba(22, 223, 253, 0.45));
}

.register-nav-back:active:not([disabled]) {
  color: var(--white-100);
  text-shadow: 0 0 10px rgba(22, 223, 253, 0.85), 0 0 22px rgba(22, 223, 253, 0.6), 0 0 36px rgba(22, 223, 253, 0.4);
}

.register-nav-back:active:not([disabled]) .register-nav-back-icon {
  opacity: 1;
  filter: drop-shadow(0 0 6px rgba(22, 223, 253, 0.7)) drop-shadow(0 0 14px rgba(22, 223, 253, 0.45));
}

.register-submit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.register-submit-btn[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

/* Replace footer with loading overlay when submitting */
.register-form.is-submitting .register-footer {
  display: none !important;
}

.register-submit-overlay {
  position: absolute;
  inset: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.9);
  border-radius: 16px;
  opacity: 0;
  pointer-events: none;
  transition: none;
}

.register-form.is-submitting .register-submit-overlay {
  opacity: 1;
  pointer-events: auto;
}

.register-submit-overlay-content {
  text-align: center;
  color: #f4f3ff;
  font-family: 'Urbanist', sans-serif;
  font-size: 18px;
  font-weight: 500;
}

.register-submit-spinner {
  width: 40px;
  height: 40px;
  margin: 0 auto;
  border: 3px solid rgba(244, 243, 255, 0.2);
  border-top-color: var(--neon-500, #16dffd);
  border-radius: 50%;
  animation: register-spin 0.8s linear infinite;
}

@keyframes register-spin {
  to { transform: rotate(360deg); }
}

.register-success-actions {
  margin-top: 40px;
  display: flex;
  justify-content: center;
}

/* Match Contact us button (header-btn) styling - separate class to avoid contact modal */
.register-explore-more-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--bg-brand-dark);
  color: white;
  padding: 12px 24px;
  border-radius: 8px;
  font-family: 'Urbanist', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 20px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  box-shadow: inset 6px 8px 9px 0px #ff1597, inset -6px -8px 9px 0px #ff1597;
  transition: box-shadow 0.3s ease;
}

.register-explore-more-btn:hover,
.register-explore-more-btn:focus-visible {
  box-shadow: inset 6px 8px 9px 0px #ff1597, inset -6px -8px 9px 0px #ff1597, 0 0 16px rgba(255, 21, 151, 0.75), 0 0 36px rgba(255, 21, 151, 0.45);
  outline: none;
}

.register-field--client-error input,
.register-field--client-error textarea,
.register-field--client-error select {
  border-color: var(--register-highlight);
  border-width: 2px;
  box-shadow: var(--register-highlight-shadow);
  transition: border-color 0.4s ease-out, box-shadow 0.4s ease-out;
}

/* Ticket/package: stronger glow on validation fail (client + server) */
.register-field--client-error #ticket_type,
.register-field:has(.register-error) #ticket_type {
  border-color: rgba(148, 163, 253, 0.85);
  box-shadow: 0 0 16px rgba(148, 163, 253, 0.5), 0 0 32px rgba(148, 163, 253, 0.35), 0 0 48px rgba(148, 163, 253, 0.2);
}

/* Payment method, dance role, experience years: legend glow in edit-field color, no frame */
.register-field--client-error[data-validate="payment"] legend,
.register-field--client-error[data-validate="role"] legend,
.register-field--client-error[data-validate="experience"] legend,
fieldset[data-validate="payment"]:has(.register-error) legend,
fieldset[data-validate="role"]:has(.register-error) legend,
fieldset[data-validate="experience"]:has(.register-error) legend {
  color: var(--register-highlight);
  text-shadow: var(--register-highlight-shadow);
  transition: color 0.2s ease-out, text-shadow 0.2s ease-out;
}


.register-type-grid--client-error,
.register-events-list--client-error {
  border: 2px solid var(--register-highlight);
  box-shadow: var(--register-highlight-shadow);
  border-radius: 16px;
  transition: border-color 0.4s ease-out, box-shadow 0.4s ease-out;
}

/* Step 4: Payment QR code */
.register-step-payment {
  text-align: center;
}

.register-payment-step-content {
  padding: 20px 0;
}

.register-success-title {
  font-family: 'Urbanist', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--success-color, var(--text-primary));
  margin: 0 0 12px;
}

.register-payment-title {
  font-family: 'Urbanist', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 12px;
}

.register-payment-subtitle {
  font-size: 16px;
  color: rgba(244, 243, 255, 0.9);
  margin: 0 0 24px;
}

.register-qr-block {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  padding: 24px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 16px;
  margin-bottom: 24px;
}

.register-invoice-email {
  font-size: 16px;
  color: rgba(244, 243, 255, 0.85);
  margin: 0 0 24px;
}
.register-invoice-email + .register-invoice-email {
  margin-top: -16px;
}

.register-qr-caption {
  font-family: 'Urbanist', sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--text-primary);
  margin: 0 0 16px;
}

.register-qr-wrapper {
  padding: 12px;
  background: #ffffff;
  border-radius: 12px;
}

.register-qr-link-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 16px;
}

.register-qr-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.12);
  color: rgba(244, 243, 255, 0.95);
  padding: 10px 18px;
  border-radius: 8px;
  font-family: 'Urbanist', sans-serif;
  font-weight: 500;
  font-size: 14px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.register-qr-link-btn:hover,
.register-qr-link-btn:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.35);
  outline: none;
}

.register-qr-canvas {
  display: block;
  border-radius: 4px;
}

.register-qr-instructions {
  margin-top: 28px;
  max-width: 400px;
  text-align: left;
}

.register-qr-instructions p {
  font-size: 14px;
  color: rgba(244, 243, 255, 0.85);
  margin: 0;
  line-height: 1.5;
}

@media (max-width: 768px) {
  /* Header: use global mobile.css rules (same as home hero) — no page-specific bar sizing */

  .register-hero {
    padding: max(88px, calc(env(safe-area-inset-top) + 72px)) 0 0;
  }

  .register-title {
    font-size: 26px;
    line-height: 1.2;
    margin-bottom: 16px;
    letter-spacing: 0.02em;
  }

  .register-hero-subtitle-title {
    font-size: 22px;
    line-height: 1.25;
  }

  .register-hero-subtitle-meta {
    font-size: 14px;
    line-height: 1.35;
  }

  .register-card {
    padding: 18px 14px 22px;
  }

  .register-steps-header {
    gap: 0;
    overflow: visible;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
    padding-bottom: 0;
    width: 100%;
  }

  .register-step-indicator {
    flex: 1 1 0;
    min-width: 0;
    flex-direction: column;
    align-items: center;
    gap: 6px;
  }

  .register-steps-header .register-step-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    min-width: 0;
  }

  .register-steps-header .register-step-help {
    display: none;
  }

  .register-steps-header .register-step-label {
    font-size: 10px;
    line-height: 1.25;
    font-weight: 700;
    padding: 0 1px;
    max-width: 100%;
    word-wrap: break-word;
    hyphens: auto;
  }

  .register-type-grid {
    grid-template-columns: 1fr;
  }

  .register-events-list {
    grid-template-columns: 1fr;
  }

  .register-grid {
    grid-template-columns: 1fr;
  }

  /* Step 3: smaller controls so the form fits mobile width */
  .register-step[data-step="3"] .register-grid {
    gap: 10px 12px;
    margin-top: 2px;
  }

  .register-step[data-step="3"] .register-field {
    gap: 3px;
    min-width: 0;
  }

  .register-step[data-step="3"] .register-field label,
  .register-step[data-step="3"] .register-field legend {
    font-size: 15px;
    line-height: 1.3;
    font-weight: 500;
  }

  .register-step[data-step="3"] .register-field input[type="text"],
  .register-step[data-step="3"] .register-field input[type="email"],
  .register-step[data-step="3"] .register-field textarea,
  .register-step[data-step="3"] .register-field select {
    padding: 8px 12px;
    font-size: 15px;
    line-height: 1.35;
    border-radius: 12px;
    min-width: 0;
  }

  .register-step[data-step="3"] #ticket_type {
    padding-right: 40px;
    background-position: right 12px center;
    background-size: 11px 7px;
  }

  .register-step[data-step="3"] .register-options {
    gap: 6px;
  }

  .register-step[data-step="3"] [data-validate="payment"] .register-options,
  .register-step[data-step="3"] [data-validate="role"] .register-options,
  .register-step[data-step="3"] [data-validate="experience"] .register-options {
    gap: 6px 8px;
  }

  .register-step[data-step="3"] .register-option {
    padding: 6px 10px;
    font-size: 14px;
    line-height: 1.25;
    border-radius: 12px;
  }

  .register-step[data-step="3"] [data-validate="payment"] .register-option,
  .register-step[data-step="3"] [data-validate="role"] .register-option,
  .register-step[data-step="3"] [data-validate="experience"] .register-option {
    padding: 6px 10px;
    gap: 8px;
    border-radius: 12px;
  }

  .register-step[data-step="3"] [data-validate="payment"] .register-option span,
  .register-step[data-step="3"] [data-validate="role"] .register-option span,
  .register-step[data-step="3"] [data-validate="experience"] .register-option span {
    font-size: 14px;
    line-height: 1.25;
    word-break: break-word;
  }

  .register-step[data-step="3"] [data-validate="payment"] .register-option input[type="radio"],
  .register-step[data-step="3"] [data-validate="role"] .register-option input[type="radio"],
  .register-step[data-step="3"] [data-validate="experience"] .register-option input[type="radio"] {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
  }

  .register-step[data-step="3"] [data-validate="payment"] .register-option input[type="radio"]:checked,
  .register-step[data-step="3"] [data-validate="role"] .register-option input[type="radio"]:checked,
  .register-step[data-step="3"] [data-validate="experience"] .register-option input[type="radio"]:checked {
    background: radial-gradient(circle at center, #16dffd 0 5px, #05122b 5px 100%);
  }

  .register-step[data-step="3"] [data-validate="experience"] .register-options {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 6px;
  }

  .register-step[data-step="3"] [data-validate="experience"] .register-option-pill {
    padding-inline: 6px;
    justify-content: center;
  }

  .register-step[data-step="3"] .register-secret-code-status {
    font-size: 12px;
  }

  .register-step[data-step="3"] .register-terms {
    font-size: 11px;
    line-height: 1.35;
    gap: 6px;
  }

  .register-step[data-step="3"] .register-terms input[type="checkbox"] {
    width: 22px;
    height: 22px;
    min-width: 22px;
    min-height: 22px;
    margin-top: 1px;
  }

  .register-step[data-step="3"] .register-terms input[type="checkbox"]:checked {
    background-size: 18px 18px;
  }

  .register-footer {
    flex-direction: column-reverse;
    align-items: stretch;
  }

  .register-nav-btn,
  .register-submit-btn {
    width: 100%;
  }

  /* Space between input and code: margin works where grid column-gap was unreliable */
  .register-captcha-row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: auto auto;
    gap: 6px 0;
    column-gap: 0;
    align-items: center;
    padding-bottom: 0;
  }

  .register-captcha-block label {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .register-captcha-block input {
    grid-column: 1;
    grid-row: 2;
    max-width: none;
    width: 100%;
    min-width: 0;
  }

  .register-captcha-code {
    grid-column: 2;
    grid-row: 2;
    margin-top: 0;
    margin-inline-start: 28px;
    justify-self: start;
    align-self: center;
    width: auto;
    max-width: none;
    text-align: left;
    font-size: clamp(16px, 5vw, 22px);
    letter-spacing: 0.1em;
    padding-bottom: 0;
  }

  .register-captcha-row .register-error-full {
    grid-column: 1 / -1;
    grid-row: 3;
  }
}

@media (max-width: 480px) {
  .register-hero {
    padding-top: max(76px, calc(env(safe-area-inset-top) + 60px));
  }
}

