/* [project]/src/app/form.css [app-client] (css) */
.page-wrapper {
  background: linear-gradient(135deg, #036 0%, #00aeee 100%);
  flex-direction: column;
  align-items: center;
  min-height: 100vh;
  padding: 2rem 1rem;
  display: flex;
}

.card {
  background: var(--white);
  border-radius: 16px;
  width: 100%;
  max-width: 520px;
  padding: 2.5rem;
  animation: .3s fadeUp;
  box-shadow: 0 8px 32px #0000002e;
}

.card.wide {
  max-width: 860px;
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.card-header {
  text-align: center;
  border-bottom: 3px solid var(--primary-yellow);
  margin-bottom: 2rem;
  padding-bottom: 1.25rem;
}

.card-header h1 {
  color: var(--primary-blue);
  margin-bottom: .25rem;
  font-size: 1.6rem;
}

.card-header h2 {
  color: var(--text-dark);
  margin-bottom: .5rem;
  font-size: 1.15rem;
  font-weight: 500;
}

.card-header p {
  color: #666;
  margin: 0;
  font-size: .9rem;
}

.step-indicator {
  justify-content: center;
  gap: .5rem;
  margin-bottom: 1rem;
  display: flex;
}

.step-dot {
  background: #ccc;
  border-radius: 50%;
  width: 10px;
  height: 10px;
  transition: background .3s;
}

.step-dot.active {
  background: var(--primary-blue);
}

.step-dot.done {
  background: var(--success);
}

.pzs-form {
  flex-direction: column;
  gap: 1.25rem;
  display: flex;
}

.form-row {
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  display: grid;
}

@media (max-width: 580px) {
  .form-row {
    grid-template-columns: 1fr;
  }

  .card {
    padding: 1.5rem;
  }
}

.form-group {
  flex-direction: column;
  gap: .4rem;
  display: flex;
}

.form-group label {
  color: #444;
  text-transform: uppercase;
  letter-spacing: .03em;
  font-size: .88rem;
  font-weight: 600;
}

.form-group .required-star {
  color: var(--error);
  margin-left: 2px;
}

.form-group input, .form-group select, .form-group textarea {
  box-sizing: border-box;
  background: #fafafa;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  width: 100%;
  padding: .7rem .9rem;
  font-family: inherit;
  font-size: .98rem;
  transition: border-color .2s, box-shadow .2s;
}

@keyframes vipGlow {
  0% {
    box-shadow: 0 0 5px #84cc1666, inset 0 0 0 1px #84cc1633;
  }

  50% {
    box-shadow: 0 0 15px #84cc16cc, inset 0 0 0 1px #84cc1680;
  }

  100% {
    box-shadow: 0 0 5px #84cc1666, inset 0 0 0 1px #84cc1633;
  }
}

.vip-role-option label {
  color: #4d7c0f;
  background: linear-gradient(145deg, #fff, #f7fee7);
  border-color: #bef264;
  animation: 2.5s ease-in-out infinite alternate vipGlow;
}

.vip-role-option label:hover {
  background: #ecfccb;
}

.vip-role-option input[type="radio"]:checked + label {
  color: #fff;
  background: linear-gradient(135deg, #84cc16, #4d7c0f);
  border-color: #4d7c0f;
  animation: none;
  box-shadow: 0 4px 12px #84cc1666;
}

.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--primary-blue);
  background: #fff;
  outline: none;
  box-shadow: 0 0 0 3px #0033661a;
}

.form-group input:required:placeholder-shown, .form-group textarea:required:placeholder-shown, .form-group select:required:invalid {
  background-color: #fff1f2;
  border-color: #fda4af;
}

.form-group input:disabled, .form-group select:disabled {
  cursor: not-allowed;
  opacity: .75;
  background-color: #f3f4f6;
}

.form-group textarea {
  resize: vertical;
  min-height: 80px;
}

.radio-group {
  flex-wrap: wrap;
  gap: .75rem;
  display: flex;
}

.radio-option {
  flex: 1;
  min-width: 90px;
}

.radio-option input[type="radio"] {
  display: none;
}

.radio-option label {
  cursor: pointer;
  text-align: center;
  color: #555;
  text-transform: none;
  letter-spacing: 0;
  border: 2px solid #d1d5db;
  border-radius: 8px;
  padding: .6rem 1rem;
  font-size: .9rem;
  font-weight: 600;
  transition: all .2s;
  display: block;
}

.radio-option input[type="radio"]:checked + label {
  border-color: var(--primary-blue);
  background: var(--primary-blue);
  color: #fff;
}

.member-section {
  background: #f9fafb;
  border: 1.5px solid #e5e7eb;
  border-radius: 12px;
  margin-bottom: 1rem;
  padding: 1.5rem;
  position: relative;
}

.member-section-header {
  border-bottom: 1px solid #e5e7eb;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.25rem;
  padding-bottom: .75rem;
  display: flex;
}

.member-section-header h4 {
  color: var(--primary-blue);
  align-items: center;
  gap: .5rem;
  margin: 0;
  font-size: 1rem;
  display: flex;
}

.verified-badge {
  color: #166534;
  background: #dcfce7;
  border-radius: 20px;
  align-items: center;
  gap: .3rem;
  padding: .2rem .6rem;
  font-size: .78rem;
  font-weight: 600;
  display: inline-flex;
}

.section-divider {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  margin-bottom: 1.25rem;
  padding: 1.25rem 1.5rem;
}

.section-divider h3 {
  color: #1d4ed8;
  align-items: center;
  gap: .5rem;
  margin: 0 0 1rem;
  font-size: 1rem;
  font-weight: 700;
  display: flex;
}

.btn {
  background-color: var(--primary-blue);
  color: var(--white);
  cursor: pointer;
  border: none;
  border-radius: 8px;
  justify-content: center;
  align-items: center;
  gap: .4rem;
  padding: .85rem 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  transition: background-color .2s, transform .1s;
  display: inline-flex;
}

.btn:hover:not(:disabled) {
  background-color: #024;
  transform: translateY(-1px);
}

.btn:active:not(:disabled) {
  transform: translateY(0);
}

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

.btn-outline {
  color: var(--primary-blue);
  border: 2px solid var(--primary-blue);
  background: none;
}

.btn-outline:hover:not(:disabled) {
  background: var(--primary-blue);
  color: #fff;
}

.btn-danger {
  background-color: #dc2626;
}

.btn-danger:hover:not(:disabled) {
  background-color: #b91c1c;
}

.btn-success {
  background-color: var(--success);
}

.btn-sm {
  padding: .45rem .9rem;
  font-size: .85rem;
}

.btn-full {
  width: 100%;
}

.form-actions {
  border-top: 1px solid #e5e7eb;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1rem;
  padding-top: 1.25rem;
  display: flex;
}

.error-msg {
  color: var(--error);
  background-color: #dc262614;
  border: 1px solid #dc262633;
  border-radius: 8px;
  padding: .7rem 1rem;
  font-size: .88rem;
}

.info-msg {
  color: #1d4ed8;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 8px;
  padding: .7rem 1rem;
  font-size: .88rem;
}

.success-card {
  text-align: center;
}

.success-icon {
  margin-bottom: 1rem;
  font-size: 4rem;
}

.success-card h2 {
  color: var(--success);
  margin-bottom: .75rem;
  font-size: 1.5rem;
}

.success-card p {
  color: #555;
  margin-bottom: 1.5rem;
  line-height: 1.6;
}

.vip-checkbox-label {
  color: #4d7c0f;
  cursor: pointer;
  background: linear-gradient(145deg, #fff, #f7fee7);
  border: 2px solid #bef264;
  border-radius: 8px;
  align-items: center;
  gap: .75rem;
  width: 100%;
  padding: 1rem 1.25rem;
  transition: all .2s;
  animation: 2.5s ease-in-out infinite alternate vipGlow;
  display: flex;
}

.vip-checkbox-label:hover {
  background: #ecfccb;
}

.vip-checkbox-label input[type="checkbox"] {
  accent-color: #65a30d;
  cursor: pointer;
  width: 1.25rem;
  height: 1.25rem;
  margin: 0;
}

.vip-checkbox-label.checked {
  color: #fff;
  background: linear-gradient(135deg, #84cc16, #4d7c0f);
  border-color: #4d7c0f;
  animation: none;
  box-shadow: 0 4px 12px #84cc1666;
}

/*# sourceMappingURL=src_app_form_021fb6b0.css.map*/