/* Modern mobile login styles inspired by Angular Material (no JS) */
:root {
  --color-bg: #fafafa;
  --color-surface: #ffffff;
  --color-text: #111827; /* slate-900 */
  --color-muted: #6b7280; /* gray-500 */
  --color-primary: #3f51b5; /* Material Indigo 500 */
  --color-on-primary: #ffffff;
  --color-error: #f44336; /* Material Red 500 */
  --elevation-1: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.24);
  --radius: 12px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --color-bg: #121212; /* Material dark background */
    --color-surface: #1e1e1e; /* Material dark surface */
    --color-text: #e5e7eb; /* slate-200 */
    --color-muted: #9ca3af; /* gray-400 */
    --color-primary: #e91e63; /* Material Pink 500 (used as primary in app dark theme) */
    --color-on-primary: #ffffff;
    --color-error: #ef5350; /* Material Red 400 */
  }
}

html, body { height: 100%; }

body#body.mobile-login {
  margin: 0;
  font-family: Roboto, "Helvetica Neue", Arial, sans-serif;
  background: var(--color-bg);
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.mobile-login .page {
  min-height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.mobile-login .card {
  width: 100%;
  max-width: 420px;
  background: var(--color-surface);
  border-radius: var(--radius);
  box-shadow: var(--elevation-1);
  padding: 24px 20px;
}

.card-header { text-align: center; margin-bottom: 16px; }
.lock-icon { font-size: 40px; color: var(--color-primary); }
.title { font-weight: 500; font-size: 20px; margin-top: 8px; }
.subtitle { color: var(--color-muted); margin-top: 2px; font-size: 14px; }

.flash { border-radius: 10px; padding: 12px 14px; font-size: 14px; margin: 12px 0; }
.flash.error {
  color: var(--color-error);
  border: 1px solid color-mix(in srgb, var(--color-error) 40%, transparent);
  background: color-mix(in srgb, var(--color-error) 8%, transparent);
}
@supports not (color: color-mix(in srgb, red, white)) {
  .flash.error { border-color: rgba(244,67,54,.4); background: rgba(244,67,54,.08); }
}

.form-fields { display: flex; flex-direction: column; gap: 12px; margin-top: 8px; }
.form-field .label { display: block; font-size: 13px; color: var(--color-muted); margin-bottom: 6px; }
.input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid rgba(0,0,0,.14);
  background: transparent;
  color: var(--color-text);
  border-radius: 10px;
  padding: 12px 14px;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
@media (prefers-color-scheme: dark) {
  .input { border-color: rgba(255,255,255,.16); }
}
.input::placeholder { color: var(--color-muted); }
.input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary) 20%, transparent);
}
@supports not (color: color-mix(in srgb, red, white)) {
  .input:focus { box-shadow: 0 0 0 3px rgba(63,81,181,.2); }
}

.section { margin-top: 8px; margin-bottom: 2px; }
.section-title { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.section-subtitle { color: var(--color-muted); font-size: 12px; }

.actions { margin-top: 20px; display: flex; justify-content: flex-end; }
.button { -webkit-appearance: none; appearance: none; border: none; padding: 12px 16px; border-radius: 999px; font-weight: 500; font-size: 15px; cursor: pointer; }
.button.primary { background: var(--color-primary); color: var(--color-on-primary); box-shadow: 0 2px 4px rgba(0,0,0,.2); }
.button.primary:active { transform: translateY(1px); box-shadow: 0 1px 2px rgba(0,0,0,.2); }

hr { border: none; border-top: 1px solid rgba(0,0,0,.08); }
@media (prefers-color-scheme: dark) {
  hr { border-top-color: rgba(255,255,255,.08); }
}

/* Disabled-looking style for readonly inputs so value is still submitted */
.input[readonly] {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.12);
  cursor: not-allowed;
}
.input[readonly]:focus {
  box-shadow: none;
  border-color: rgba(0,0,0,.12);
}
@media (prefers-color-scheme: dark) {
  .input[readonly] {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.16);
  }
  .input[readonly]:focus {
    border-color: rgba(255,255,255,.16);
  }
}
