:root {
  --color-bg: #f6f7fb; --color-surface: #ffffff; --color-text: #172033;
  --color-muted: #5f6b7a; --color-border: #d8dde8; --color-primary: #2251c7;
  --color-primary-hover: #183f9f; --color-danger-border: #d1432f;
  --color-focus: #ffbf47; --shadow-card: 0 24px 60px rgba(23, 32, 51, 0.12);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

body {
  min-height: 100vh;
  margin: 0;
  color: var(--color-text);
  background: radial-gradient(circle at top, #eef3ff 0, var(--color-bg) 42rem);
}

.page-shell {
  display: grid;
  min-height: 100vh;
  place-items: center;
  padding: 2rem 1rem;
}

.card {
  width: min(100%, 30rem);
  padding: 2rem;
  border: 1px solid var(--color-border);
  border-radius: 1.25rem;
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
}

.card--error { border-top: 0.4rem solid var(--color-danger-border); }

.eyebrow {
  margin-bottom: 0.75rem;
  color: var(--color-primary);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

h1 {
  margin: 0 0 0.75rem;
  font-size: clamp(1.8rem, 5vw, 2.4rem);
  line-height: 1.1;
}

.lede, .help-text { color: var(--color-muted); line-height: 1.55; }

.login-form {
  display: grid;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

label { font-weight: 700; }

input {
  width: 100%;
  min-height: 3rem;
  padding: 0.75rem 0.9rem;
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  color: var(--color-text);
  font: inherit;
}

input:focus, a:focus, button:focus { outline: 3px solid var(--color-focus); outline-offset: 3px; }
input[aria-invalid="true"] { border-color: var(--color-danger-border); }
.field-error { margin: -0.25rem 0 0; color: var(--color-danger-border); font-size: 0.9rem; font-weight: 600; }
.help-text { margin: 0 0 0.5rem; font-size: 0.92rem; }
.request-meta { padding: 0.85rem 1rem; border-radius: 0.75rem; }

.google-button {
  display: inline-flex;
  min-height: 3.1rem;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  border: 0;
  border-radius: 0.75rem;
  background: var(--color-primary);
  color: #ffffff;
  cursor: pointer;
  font: inherit;
  font-weight: 700;
}

.google-button:hover { background: var(--color-primary-hover); }

.button-mark {
  display: inline-grid;
  width: 1.5rem;
  height: 1.5rem;
  place-items: center;
  border-radius: 50%;
  background: #ffffff;
  color: var(--color-primary);
  font-weight: 800;
}

.brand-logo { display: block; height: 2.5rem; width: auto; max-width: 100%; margin-bottom: 1.25rem; }
.brand-footer { margin: 1.5rem 0 0; color: var(--color-muted); font-size: 0.85rem; }

.request-meta { margin: 1.25rem 0; background: #f1f4f9; }
.request-meta dt { color: var(--color-muted); font-size: 0.82rem; font-weight: 700; text-transform: uppercase; }
.request-meta dd { margin: 0.35rem 0 0; overflow-wrap: anywhere; }
.support-link, .secondary-link { color: var(--color-primary); font-weight: 700; }

.picker-form { margin-top: 1.5rem; }
.picker-list { display: grid; gap: 0.75rem; margin: 0; padding: 0; list-style: none; }

.picker-card {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  width: 100%;
  min-height: 3.1rem;
  align-items: flex-start;
  justify-content: center;
  padding: 0.9rem 1.1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.picker-card:hover { border-color: var(--color-primary); background: #f1f4f9; }
.picker-card-label { font-weight: 700; }
.picker-card-detail { color: var(--color-muted); font-size: 0.85rem; }
