:root {
  --bg: #f2f0ea;
  --surface: #fbfaf7;
  --text: #18231f;
  --muted: #59665f;
  --accent: #1e6f57;
  --accent-strong: #154f3e;
  --border: #d6d0c4;
  --danger: #932f2f;
  color: var(--text);
  font-family: "Aptos", "Segoe UI", "Helvetica Neue", sans-serif;
}

* {
  box-sizing: border-box;
}

body {
  background: linear-gradient(180deg, #f8f6f1 0%, var(--bg) 100%);
  margin: 0;
  min-height: 100vh;
}

button,
input {
  font: inherit;
}

.login-shell {
  align-items: center;
  display: grid;
  min-height: 100vh;
  padding: 24px;
}

.login-card {
  background: linear-gradient(180deg, #ffffff 0%, #faf7f1 100%);
  border: 1px solid var(--border);
  border-radius: 10px;
  display: grid;
  gap: 14px;
  margin: 0 auto;
  max-width: 420px;
  padding: 24px;
  width: 100%;
}

.login-accent {
  background: linear-gradient(90deg, rgba(30, 111, 87, 0.88) 0%, rgba(184, 138, 47, 0.72) 100%);
  border-radius: 999px;
  height: 3px;
  width: 100%;
}

.login-brand {
  align-items: center;
  display: inline-flex;
  gap: 12px;
}

.login-brand__logo {
  display: block;
  height: 46px;
  object-fit: contain;
  width: auto;
}

.login-brand__copy {
  display: grid;
  gap: 2px;
}

.login-brand__kicker {
  color: var(--accent-strong);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.login-brand__title {
  font-size: 1.04rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.login-card h1 {
  margin: 0;
}

.login-copy,
.login-support {
  color: var(--muted);
  margin: 0;
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-field {
  display: grid;
  gap: 7px;
}

.login-field span {
  font-size: 0.9rem;
  font-weight: 700;
}

.login-field input {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text);
  min-height: 44px;
  padding: 10px 12px;
}

.login-button {
  background: var(--accent);
  border: 1px solid transparent;
  border-radius: 10px;
  color: #fff;
  cursor: pointer;
  min-height: 42px;
  padding: 10px 14px;
}

.login-button:hover {
  background: var(--accent-strong);
}

.login-link {
  background: none;
  border: 0;
  color: var(--accent);
  justify-self: start;
  padding: 0;
  text-decoration: none;
}

.login-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.login-link--button {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  text-decoration: none;
}

.login-link:hover {
  color: var(--accent-strong);
  text-decoration: underline;
}

.login-link--button:hover {
  background: rgba(30, 111, 87, 0.06);
  text-decoration: none;
}

.login-link:disabled {
  color: var(--muted);
  cursor: not-allowed;
  text-decoration: none;
}

.login-notice {
  background: rgba(246, 226, 222, 0.72);
  border: 1px solid rgba(147, 47, 47, 0.18);
  border-radius: 10px;
  color: var(--danger);
  padding: 12px 14px;
}

.login-notice--success {
  background: rgba(222, 242, 233, 0.8);
  border-color: rgba(30, 111, 87, 0.18);
  color: var(--accent-strong);
}
