/* Shared layout. Brand-specific colors/fonts/radii come from tokens-<brand>.css. */

.lf-form { display: flex; flex-direction: column; }

.lf-input {
  width: 100%;
  padding: var(--lf-input-pad-y) var(--lf-input-pad-x);
  border: 1px solid var(--lf-border);
  border-radius: var(--lf-input-radius);
  background: var(--lf-input-bg);
  font: var(--lf-input-font);
  color: var(--lf-ink);
  margin-bottom: var(--lf-input-gap);
  outline: none;
  transition: border-color 0.18s, box-shadow 0.18s;
}
.lf-input:focus {
  border-color: var(--lf-accent);
  box-shadow: var(--lf-input-focus-shadow);
}
.lf-input::placeholder { color: var(--lf-muted); font-weight: 400; }

.lf-link {
  display: inline-block;
  font-family: var(--lf-link-font-family);
  font-style: var(--lf-link-font-style);
  font-size: var(--lf-link-font-size);
  color: var(--lf-accent);
  text-decoration: underline;
  margin: var(--lf-link-margin);
  cursor: pointer;
  align-self: flex-start;
}

.lf-error {
  background: var(--lf-error-bg);
  color: var(--lf-error-ink);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 13px;
  margin: -2px 0 12px;
  line-height: 1.45;
}

.lf-cta {
  width: 100%;
  background: var(--lf-accent);
  color: var(--lf-cta-ink);
  border: none;
  padding: var(--lf-cta-pad-y) var(--lf-cta-pad-x);
  border-radius: var(--lf-cta-radius);
  font: var(--lf-cta-font);
  cursor: pointer;
  transition: background 0.18s;
}
.lf-cta:hover:not([disabled]) { background: var(--lf-accent-hover); }
.lf-cta[disabled] { opacity: 0.55; cursor: default; }

.lf-micro {
  text-align: center;
  font-size: 12px;
  color: var(--lf-muted);
  margin-top: var(--lf-micro-gap);
  line-height: 1.55;
}

/* Confirmation card content. Sits in the same container the form sat in. */
.lf-confirm {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 4px 0;
}
.lf-confirm-check {
  width: 36px; height: 36px;
  background: var(--lf-accent); color: var(--lf-cta-ink);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px; font-weight: 700;
  flex-shrink: 0;
}
.lf-confirm-body { padding-top: 4px; }
.lf-confirm-primary {
  font-family: var(--lf-confirm-font-family);
  font-size: var(--lf-confirm-font-size);
  font-weight: 600;
  color: var(--lf-ink);
  line-height: 1.4;
}
.lf-confirm-primary b { color: var(--lf-ink); font-weight: 700; }
.lf-confirm-secondary {
  font-size: 13px;
  color: var(--lf-slate);
  line-height: 1.55;
  margin-top: 6px;
}
.lf-confirm-secondary b { color: var(--lf-ink); font-weight: 600; }
