/* ═══════════════════════════════════════
   LOGIN.CSS — Login page styles
   ═══════════════════════════════════════ */

.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 20px;
  max-width: var(--max-w);
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* Logo */
.login-logo { text-align: center; margin-bottom: 36px; }
.login-flag {
  font-size: 3.5rem;
  display: block;
  margin-bottom: 14px;
  animation: float 3s ease-in-out infinite;
}
.login-title {
  font-size: 2.2rem;
  font-weight: 900;
  letter-spacing: -2px;
  background: linear-gradient(135deg, #fff 0%, var(--violet2) 50%, var(--emerald2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 6px;
}
.login-subtitle { font-size: .82rem; color: var(--text3); letter-spacing: .5px; }

/* Card */
.login-card {
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 28px;
  padding: 32px 28px;
  box-shadow: var(--shadow-lg);
  animation: scaleIn 0.4s var(--ease-spring);
  position: relative;
  overflow: hidden;
}
/* Glow top edge */
.login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 20%; right: 20%;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--violet), transparent);
}

.login-welcome  { font-size: 1.1rem; font-weight: 800; margin-bottom: 4px; }
.login-sub      { font-size: .78rem; color: var(--text2); margin-bottom: 28px; }

/* Error */
.error-alert {
  background: var(--danger-dim);
  border: 1px solid var(--danger);
  border-radius: var(--r-sm);
  padding: 10px 14px;
  font-size: .82rem;
  color: var(--rose2);
  margin-bottom: 16px;
  display: none;
}
.error-alert.show {
  display: block;
  animation: shake 0.35s ease;
}

/* Creator */
.creator-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 28px;
}
.creator-avatar {
  width: 32px; height: 32px;
  min-width: 32px; min-height: 32px;
  max-width: 32px; max-height: 32px;
  border-radius: 50%;
  border: 1.5px solid var(--border2);
  object-fit: cover;
  flex-shrink: 0;
  display: block;
}
.creator-info { text-align: left; }
.creator-made { font-size: .62rem; color: var(--text3); letter-spacing: 1px; text-transform: uppercase; }
.creator-name {
  font-size: .82rem;
  font-weight: 700;
  color: var(--text2);
  transition: color var(--dur);
}
.creator-name:hover { color: var(--violet2); }
