/* =========================
   Lead Form (pure CSS)
   Namespace: .lm-lead-form
   ========================= */

.lm-lead-form .pulse {
  animation: lm-pulse-animation 2s infinite;
}

@keyframes lm-pulse-animation {
  0% { box-shadow: 0 0 0 0 rgba(0,0,0,0.2); }
  100% { box-shadow: 0 0 0 10px rgba(0,0,0,0); }
}

.lm-lead-form .lead-form-container {
  display: flex;
  justify-content: center;
  align-items: center;
}

.lm-lead-form .lead-manager-form {
  box-shadow: rgba(0, 0, 0, 0.15) 0 2px 8px;
  width: clamp(260px, 100%, 500px);
  position: relative;
  padding: 2rem;
  background: #fff;
}

/* Header */
.lm-lead-form .lead-manager-form .lead-form-title {
  color: rgb(30 126 185);
  font-size: 2.2rem;
  text-align: center;
  margin-top: 0;
  margin-bottom: 2rem;
  font-weight: 700;
}

.lm-lead-form .lead-manager-form .step-instruction {
  font-size: 1.4rem;
  color: #444;
  font-weight: 600;
}

.lm-lead-form .lead-manager-form .step-indicator {
  margin: 0;
}

.lm-lead-form .lead-manager-form .step-text-info {
  font-size: 1.3rem;
  color: #7d7d7d;
  font-weight: 700;
  margin-left: 1rem;
}

/* Progress */
.lm-lead-form .lead-manager-form .step-progress {
  position: relative;
  height: 1rem;
  border-radius: 3rem;
  background: rgba(105, 172, 53, 0.276);
}

.lm-lead-form .lead-manager-form .step-progress::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 50%;
  height: 100%;
  border-radius: 3rem;
  background-color: rgb(104 172 53);
  transition: width .5s ease-out;
}

.lm-lead-form .lead-manager-form .step-progress.step-2::before {
  width: 100%;
}

/* Viewport */
.lm-lead-form .lead-manager-form .step-viewport {
  display: flex;
  gap: 2rem;
  overflow-x: auto;
  justify-content: flex-start;
  align-items: center;
  scroll-snap-type: x mandatory;
  -ms-overflow-style: none;
  scrollbar-width: none;
  padding-top: 2rem;
}

.lm-lead-form .lead-manager-form .step-viewport::-webkit-scrollbar {
  display: none;
}

.lm-lead-form .lead-manager-form .step-viewport section {
  position: relative;
  width: 100%;
  height: 100%;
  flex: 1 0 auto;
  scroll-snap-align: center;
  scroll-snap-stop: always;
}

/* Replace :has(:invalid)+section hiding using a class toggled by JS */
.lm-lead-form .lead-manager-form.is-step1-invalid #step-2 {
  display: none;
}

/* Groups */
.lm-lead-form .lead-manager-form .lead-form-group {
  position: relative;
  margin-bottom: 15px;
}

.lm-lead-form .lead-manager-form .lead-form-group .hint {
  font-size: 1.3rem;
  font-weight: 500;
  color: #2265238f;
}

/* Inputs base */
.lm-lead-form .lead-manager-form .lead-form-group input:not([type='radio']),
.lm-lead-form .lead-manager-form .lead-form-group .radio-group {
  display: block;
  width: 100%;
  height: 44px;
  background: transparent;
  border: 1px solid #ccc;
  border-radius: 5px;
  transition: border-color .3s ease, box-shadow .3s ease;
  padding: 0 15px;
  font-weight: 700;
  color: #1d7db9;
  box-sizing: border-box;
}
.lm-lead-form .lead-manager-form input[type="radio"] {
  margin: 0;
  width: auto;
  vertical-align: middle;
}
.lm-lead-form .lead-manager-form .lead-form-group input[type="email"] {
  font-size: 1.4rem;
}

/* Placeholder */
.lm-lead-form .lead-manager-form .lead-form-group input::placeholder {
  font-weight: 400;
  font-size: 1.3rem;
}

/* Focus */
.lm-lead-form .lead-manager-form .lead-form-group input:not([type='radio']):focus {
  border-color: #7ab931;
  outline: none;
}

/* Floating label - default */
.lm-lead-form .lead-manager-form .lead-form-group > label,
.lm-lead-form .lead-manager-form .lead-form-group label + .radio-group {
  /* left as-is; see next rules */
}

/* Floating label positioning for non-radio inputs */
.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) > label {
  position: absolute;
  cursor: text;
  z-index: 2;
  top: 13px;
  left: 10px;
  font-size: 12px;
  font-weight: bold;
  background: #fff;
  padding: 0 10px;
  color: #999;
  transition: all .3s ease;
}

/* On focus: move label up */
.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) input:focus + label {
  font-size: 11px;
  top: -10px;
  color: blue;
}

.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) input:focus + label .hint {
  display: none;
}

/* On valid (and not invalid-field class): move label up, show check */
.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) input:valid:not(.invalid-field) + label {
  font-size: 11px;
  top: -10px;
  color: darkgreen;
}

.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) input:valid:not(.invalid-field) + label::before {
  content: "\2713";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 1rem;
  color: rgb(1, 94, 1);
}

.lm-lead-form .lead-manager-form .lead-form-group:not(.is-radio) input:valid:not(.invalid-field) + label .hint {
  display: none;
}

/* Invalid field styling */
.lm-lead-form .lead-manager-form .lead-form-group input.invalid-field {
  border-color: rgba(230, 44, 3, 0.78);
  box-shadow: 0 0 0 1px rgba(230, 44, 3, 0.2);
}
/* Radio groups */
.lm-lead-form .lead-manager-form .lead-form-group .radio-group {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.5rem;
  padding: 0 10px;
}

.lm-lead-form .lead-manager-form .lead-form-group .radio-label {
  margin: 0;
  font-weight: 400;
  cursor: pointer;
  color: #999;
}

.lm-lead-form .lead-manager-form .lead-form-group .radio-label span {
  vertical-align: middle;
  margin: 0;
}

/* Replace :has(:checked) using input:checked + span and label state */
.lm-lead-form .lead-manager-form .lead-form-group .radio-label input:checked + span {
  font-weight: 700;
  color: inherit;
}

.lm-lead-form .lead-manager-form .lead-form-group.is-radio > label {
  position: relative;
  display: inline-block;
  font-size: 11px;
  top: 0;
  left: 0;
  color: #444;
  font-weight: 700;
  margin-bottom: 6px;
}

/* --- Text alignment helpers --- */
.lm-lead-form .lead-manager-form .lead-form-group input.lm-ta-right {
  text-align: right;
}

.lm-lead-form .lead-manager-form .lead-form-group input.lm-ta-left {
  text-align: left;
}

/* On focus: always show left (partial input visible) */
.lm-lead-form .lead-manager-form .lead-form-group input:focus {
  text-align: left;
}

/* --- Radio group: center options when nothing selected --- */
.lm-lead-form .lead-manager-form .lead-form-group.is-radio .radio-group {
  justify-content: center; /* default when empty */
}

/* When selection exists, left-align like a normal field */
.lm-lead-form .lead-manager-form .lead-form-group.is-radio.is-has-selection .radio-group {
  justify-content: flex-start;
}

/* Radio label (Gender/Tobacco) behaves like "valid" when selected */
.lm-lead-form .lead-manager-form .lead-form-group.is-radio > label {
  position: absolute;
  cursor: text;
  z-index: 2;
  top: 13px;
  left: 10px;
  font-size: 12px;
  font-weight: bold;
  background: #fff;
  padding: 0 10px;
  color: #999;
  transition: all .3s ease;
}

/* When selected, float up + green + check (like valid inputs) */
.lm-lead-form .lead-manager-form .lead-form-group.is-radio.is-has-selection > label {
  font-size: 11px;
  top: -10px;
  color: darkgreen;
}

.lm-lead-form .lead-manager-form .lead-form-group.is-radio.is-has-selection > label::before {
  content: "\2713";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 1rem;
  color: rgb(1, 94, 1);
}

/* Button */
.lm-lead-form .lead-manager-form .btn-style-01 {
  display: inline-block;
  background-color: gray;
  color: #fff;
  border-radius: 20px;
  text-decoration: none;
  font-weight: 800;
  text-align: center;
  border: none;
  font-size: 1.4rem;
  height: 36px;
  line-height: 36px;
  outline: 0;
  overflow: hidden;
  padding: 0 20px;
  pointer-events: auto;
  position: relative;
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
  vertical-align: top;
  white-space: nowrap;
  z-index: 9;
  min-width: 150px;
  transition: box-shadow .2s;
}

/* Active (enabled) */
.lm-lead-form .lead-manager-form .btn-style-01:not(.disabled):not(.saved) {
  cursor: pointer;
  background-color: #fa6200;
  color: #fff;
  background-image: linear-gradient(-180deg, #FF7E31, #E62C03);
  box-shadow: rgba(0, 0, 0, 0.1) 0 2px 4px;
}

.lm-lead-form .lead-manager-form .btn-style-01:not(.disabled):not(.saved):hover {
  background-image: linear-gradient(-180deg, #ff7e31, #ff2e00);
  box-shadow: rgba(253, 76, 0, 0.5) 0 3px 8px;
  color: #fff;
}

/* Submit wrapper */
.lm-lead-form .lead-manager-form .lead-form-submit {
  position: relative;
}

.lm-lead-form .lead-manager-form .lead-form-submit .tip {
  text-align: center;
  font-size: 1.4rem;
  color: #fff;
  position: absolute;
  width: 100%;
  height: 0;
  display: none;
  transition: height 1s ease-in;
}

/* Replace :has(.lead-submit-btn:disabled):hover with wrapper class toggled by JS */
.lm-lead-form .lead-manager-form.is-tip-visible .lead-form-submit .tip {
  display: block;
  height: 100%;
  color: rgba(255, 0, 0, 0.67);
}

/* Overlay */
.lm-lead-form .lead-manager-form form {
  position: relative;
}

.lm-lead-form .lead-manager-form form .overlay {
  position: absolute;
  background: rgba(255,255,255,0.07);
  width: 100%;
  height: 100%;
  top: 0; left: 0;
  display: none;
  justify-content: center;
  align-items: center;
}

.lm-lead-form .lead-manager-form form .overlay .message-container {
  padding: 2rem;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.1) 0 2px 4px;
}

.lm-lead-form .lead-manager-form form .overlay .message-container > * {
  color: #3d8223;
  font-weight: 700;
  font-size: 1.6rem;
}

/* Show overlay when saved */
.lm-lead-form .lead-manager-form.is-saved form .overlay {
  display: flex;
  z-index: 99;
  /* backdrop-filter is nice but optional */
  backdrop-filter: blur(2px);
}

/* Lead submit button full width */
.lm-lead-form .lead-manager-form .lead-submit-btn {
  width: 100%;
}

/* Disabled style */
.lm-lead-form .lead-manager-form .lead-submit-btn.disabled {
  background-color: #ccc;
  background-image: none;
  color: #666;
  cursor: not-allowed;
  opacity: 0.6;
}

.lm-lead-form .lead-manager-form .lead-submit-btn.disabled:hover {
  background-image: none;
  box-shadow: none;
}

/* Footer */
.lm-lead-form .lead-manager-form footer .disclaimer {
  margin: 3rem 0 2rem;
  font-size: 1.3rem;
  text-align: center;
}
.lm-lead-form .lead-manager-form footer .disclaimer p {
  font-size: 16px;
  line-height: 2rem;
}

.lm-lead-form .lead-manager-form footer .secure-logos {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 5px;
}

/* ==============================
   Lead Form Errors
   ============================== */

.lm-lead-form .lm-lead-errors {
  border: 1px solid rgba(230, 44, 3, 0.35);
  background: linear-gradient(180deg, #fff6f5, #ffe9e7);
  border-radius: 8px;
  padding: 14px 16px;
  margin-bottom: 18px;
  box-shadow: rgba(0,0,0,0.05) 0 2px 4px;
  position: relative;
}

/* left accent bar */
.lm-lead-form .lm-lead-errors::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  border-radius: 8px 0 0 8px;
  background: #e62c03;
}

/* error list */
.lm-lead-form .lm-lead-errors ul {
  margin: 0;
  padding-left: 22px;
  list-style: none;
}

/* error item */
.lm-lead-form .lm-lead-errors li {
  position: relative;
  margin: 6px 0;
  font-size: 1.35rem;
  line-height: 1.45;
  color: #7a0f0f;
  font-weight: 600;
}

/* bullet icon */
.lm-lead-form .lm-lead-errors li::before {
  content: "⚠";
  position: absolute;
  left: -18px;
  top: 0;
  font-size: 1.1rem;
  color: #e62c03;
}

/* field name highlight */
.lm-lead-form .lm-lead-errors li strong {
  color: #c11900;
  font-weight: 700;
}

/* ==============================
   Inline Field Errors
   ============================== */

.lm-lead-form .lead-form-group {
  position: relative;
}

/* error message text */
.lm-lead-form .lm-field-error {
  font-size: 1.2rem;
  color: #e62c03;
  margin-top: 6px;
  min-height: 1.2rem;
  line-height: 1.3;
  font-weight: 600;
}

/* invalid input */
.lm-lead-form input:not([type="radio"]).invalid-field {
  border-color: #e62c03;
  box-shadow: 0 0 0 1px rgba(230,44,3,0.25);
}

/* label turns red when invalid */
.lm-lead-form input.invalid-field + label {
  color: #c11900;
}

/* subtle shake animation */
@keyframes lm-input-shake {
  0% { transform: translateX(0); }
  20% { transform: translateX(-3px); }
  40% { transform: translateX(3px); }
  60% { transform: translateX(-3px); }
  80% { transform: translateX(3px); }
  100% { transform: translateX(0); }
}

.lm-lead-form input.invalid-field.shake {
  animation: lm-input-shake .3s ease;
}

/* valid input indicator */
.lm-lead-form input:valid:not(.invalid-field) {
  border-color: #3d8223;
}

/* smooth transitions */
.lm-lead-form input:not([type="radio"]) {
  transition: border-color .2s ease, box-shadow .2s ease;
}

/* Mobile tweaks */
@media (max-width: 480px) {
  .lm-lead-form .lm-lead-errors {
    font-size: 1.25rem;
    padding: 12px 14px;
  }
  .lm-lead-form .lead-manager-form {
    box-shadow: none;
    padding-left: 0;
    padding-right: 0;
  }
}

.lm-lead-form input:valid:not(.invalid-field) {
  background-image: url("data:image/svg+xml,%3Csvg ...checkmark...%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 16px;
}
