/*!
 * © Rapid Surveys Pty Ltd. All rights reserved.
 * Login page chrome. Theme variables only — no hardcoded colours/fonts.
 */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--rs-color-bg);
  color: var(--rs-color-text);
  font-family: var(--rs-font-sans);
  font-size: var(--rs-text-base);
  line-height: var(--rs-line-base);
}

.lg-body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--rs-space-5);
}

.lg-card {
  width: 100%;
  max-width: 380px;
  background: var(--rs-color-surface);
  border: 1px solid var(--rs-color-border);
  border-radius: var(--rs-radius-lg);
  box-shadow: var(--rs-shadow-md);
  padding: var(--rs-space-6);
}

.lg-brand {
  display: flex;
  align-items: center;
  gap: var(--rs-space-3);
  margin-bottom: var(--rs-space-5);
}

.lg-brand__mark {
  width: 36px;
  height: 36px;
  border-radius: var(--rs-radius-md);
  background: var(--rs-color-primary);
  color: var(--rs-color-primary-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--rs-text-sm);
  font-weight: var(--rs-weight-bold);
  letter-spacing: 0.5px;
}

.lg-brand__name {
  font-family: var(--rs-font-display);
  font-weight: var(--rs-weight-semi);
  font-size: var(--rs-text-lg);
}

.lg-brand__tag {
  color: var(--rs-color-accent-gold);
  margin-left: var(--rs-space-1);
}

.lg-title {
  font-size: var(--rs-text-2xl);
  font-weight: var(--rs-weight-semi);
  margin: 0 0 var(--rs-space-4) 0;
}

.lg-error {
  background: color-mix(in srgb, var(--rs-color-danger) 12%, transparent);
  border: 1px solid var(--rs-color-danger);
  color: var(--rs-color-danger);
  padding: var(--rs-space-2) var(--rs-space-3);
  border-radius: var(--rs-radius-sm);
  font-size: var(--rs-text-sm);
  margin: 0 0 var(--rs-space-3) 0;
}

.lg-form { display: flex; flex-direction: column; gap: var(--rs-space-2); }

.lg-label {
  font-size: var(--rs-text-xs);
  font-weight: var(--rs-weight-semi);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--rs-color-text-muted);
  margin-top: var(--rs-space-2);
}

.lg-input {
  padding: var(--rs-space-3);
  border: 1px solid var(--rs-color-border);
  border-radius: var(--rs-radius-sm);
  background: var(--rs-color-surface);
  font-family: var(--rs-font-sans);
  font-size: var(--rs-text-base);
  color: var(--rs-color-text);
  width: 100%;
}

.lg-input:focus {
  outline: 2px solid var(--rs-color-primary);
  outline-offset: -1px;
  border-color: var(--rs-color-primary);
}

.lg-btn {
  margin-top: var(--rs-space-4);
  padding: var(--rs-space-3) var(--rs-space-5);
  border: 1px solid var(--rs-color-primary);
  background: var(--rs-color-primary);
  color: var(--rs-color-primary-ink);
  border-radius: var(--rs-radius-sm);
  font-family: var(--rs-font-sans);
  font-size: var(--rs-text-base);
  font-weight: var(--rs-weight-semi);
  cursor: pointer;
}

.lg-btn:hover {
  background: color-mix(in srgb, var(--rs-color-primary) 85%, black);
}

.lg-foot {
  margin: var(--rs-space-5) 0 0 0;
  text-align: center;
  color: var(--rs-color-text-soft);
  font-size: var(--rs-text-xs);
}
