/* ══════════════════════════════════════════════════════════════
   AIPA License Manager — Login Page
   Clean, professional enterprise login
   ══════════════════════════════════════════════════════════════ */

.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #F7F8FA;
  padding: 20px;
}

.login-card {
  background: #FFFFFF;
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
  width: 100%;
  max-width: 380px;
  padding: 36px 32px 28px;
  position: relative;
}

/* ── Language selector position (login card) ── */
.login-card .lang-dropdown {
  position: absolute;
  top: 12px;
  right: 12px;
}
.login-card .lang-trigger {
  background: none;
  border: none;
}
.login-card .lang-trigger:hover {
  background: rgba(0,0,0,.04);
}

/* ── Branding ── */
.login-brand {
  text-align: center;
  margin-bottom: 28px;
}
.login-brand img {
  height: 36px;
  margin-bottom: 10px;
  border-radius: 4px;
}
.login-brand h1 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -.3px;
  margin-bottom: 2px;
}
.login-brand p {
  font-size: .75rem;
  color: var(--text-3);
  font-weight: 400;
}

/* ── Form ── */
.login-form { margin-bottom: 14px; }
.login-field {
  margin-bottom: 12px;
}
.login-field label {
  display: block;
  font-size: .75rem;
  color: var(--text-2);
  font-weight: 500;
  margin-bottom: 4px;
}
.login-field input,
.login-field select,
.login-field textarea {
  width: 100%;
  padding: 9px 11px;
  background: #FFF;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text, #1F2937);
  font-family: var(--font);
  font-size: .85rem;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.login-field input::placeholder,
.login-field textarea::placeholder {
  color: var(--text-3, #6B7280);
  opacity: 1;
}
.login-field input:focus,
.login-field select:focus,
.login-field textarea:focus {
  border-color: var(--primary);
  box-shadow: none;
  outline: none;
}
.login-field input.error,
.login-field input.input-error,
.login-field select.input-error,
.login-field textarea.input-error {
  border-color: var(--danger);
  box-shadow: 0 0 0 2px rgba(239,68,68,.08);
}
.login-field .field-error-msg {
  display: none;
  font-size: 0.72rem;
  color: #EF4444;
  margin-top: 3px;
  line-height: 1.35;
  font-weight: 500;
}
.login-field .field-error-msg.show { display: block; }

/* ── Remember me ── */
.login-remember {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 16px;
  font-size: .78rem;
  color: var(--text-3);
  cursor: pointer;
}
.login-remember input {
  accent-color: var(--primary);
  width: 13px; height: 13px;
}

/* ── Submit button ── */
.login-btn {
  width: 100%;
  padding: 9px;
  background: var(--primary);
  color: #FFF;
  border: none;
  border-radius: var(--radius-sm);
  font-family: var(--font);
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.login-btn:hover:not(:disabled) { background: #0a84a3; }
.login-btn:active:not(:disabled) { background: #087793; }
.login-btn:disabled { opacity: .4; cursor: not-allowed; }

/* Account type toggle (register): CSS only — no var(--bg) from dark theme */
.login-btn.type-toggle:not(.active) {
  background: #F7F8FA;
  color: var(--text-2, #6B7280);
  border: 1px solid var(--border);
}
.login-btn.type-toggle.active {
  background: var(--primary);
  color: #FFF;
  border: 1px solid transparent;
}
.login-btn.type-toggle:not(.active):hover:not(:disabled) {
  background: #ECEFF2;
  color: var(--text-2, #6B7280);
}
.login-btn.type-toggle.active:hover:not(:disabled) {
  background: var(--primary-hover, #097a96);
}
.login-btn.type-toggle.active:active:not(:disabled) {
  background: var(--primary-dark, #097a96);
}

/* ── Loading spinner ── */
.login-btn .spinner {
  width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #FFF;
  border-radius: 50%;
  animation: spin .6s linear infinite;
  display: none;
}
.login-btn.loading .spinner,
.login-btn.btn-loading .spinner { display: block; }
.login-btn.loading .btn-text,
.login-btn.btn-loading .btn-text { display: none; }
.login-btn.btn-loading::after { display: none; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Error message ── */
.login-error {
  display: none;
  padding: 8px 10px;
  background: var(--danger-bg);
  border: 1px solid var(--danger-border);
  border-radius: var(--radius-sm);
  color: #991B1B;
  font-size: .78rem;
  margin-bottom: 12px;
}
.login-error.show { display: block; }

/* ── Toggle (login ↔ register) ── */
.login-toggle {
  text-align: center;
  font-size: .78rem;
  color: var(--text-3);
  margin-top: 14px;
}
.login-toggle a {
  color: var(--primary);
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
}
.login-toggle a:hover { text-decoration: underline; }

/* ── Footer ── */
.login-footer {
  text-align: center;
  font-size: .65rem;
  color: var(--text-3);
  margin-top: 20px;
  padding-top: 14px;
  border-top: 1px solid var(--border-light);
}

/* ── Register title ── */
#registerTitle {
  font-size: .9rem !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  margin-bottom: 14px !important;
  text-align: center;
}

/* ── Responsive ── */
@media (max-width: 480px) {
  .login-card {
    padding: 28px 20px 24px;
    border: none;
    box-shadow: none;
    max-width: 100%;
  }
  .login-page {
    padding: 0;
    background: #FFF;
  }
}

/* ── Phone prefix inline override ───────────────────────────────────────── */
.login-field .phone-input-row { display: flex !important; flex-direction: row !important; gap: 6px; align-items: stretch; }
.login-field .phone-input-row input[type="tel"] { flex: 1 1 auto !important; width: auto !important; min-width: 0 !important; margin-bottom: 0; }
.ppd-wrap > select.phone-prefix-select { display: none !important; }

