/* Login page — standalone public stylesheet. Served via /login.css
   without auth so CSP script-src/style-src 'self' can stay strict
   (no 'unsafe-inline'). */

.lang-selector {
  position: fixed;
  top: 12px;
  right: 16px;
  z-index: 1000;
}
.lang-selector select {
  padding: 6px 12px;
  border: 1.5px solid rgba(255, 255, 255, 0.4);
  border-radius: 6px;
  background: rgba(26, 10, 46, 0.85);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.05em;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: all 0.2s ease;
}
.lang-selector select:hover {
  border-color: rgba(255, 255, 255, 0.7);
  background: rgba(26, 10, 46, 0.95);
}
.lang-selector select:focus {
  outline: none;
  border-color: #a855c7;
  box-shadow: 0 0 0 3px rgba(168, 85, 199, 0.3);
}
.lang-selector select:focus-visible {
  outline: 2px solid #7b2d8e;
  outline-offset: 2px;
}
.lang-selector select option {
  background: #1a0a2e;
  color: #fff;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --purple-deep: #5a1f6e;
  --purple-main: #7b2d8e;
  --purple-light: #a855c7;
  --purple-bg: #f8f4fb;
  --purple-border: #d4b8e0;
  --text: #2c2c2c;
  --text-light: #666;
  --bg: #fefcff;
  --white: #fff;
  --shadow: 0 4px 20px rgba(90, 31, 110, 0.12);
}
body {
  font-family: 'Inter', sans-serif;
  background: linear-gradient(135deg, #f8f4fb 0%, #efe8f5 100%);
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  color: var(--text);
}
.card {
  background: var(--white);
  border-radius: 16px;
  box-shadow: var(--shadow);
  width: 100%; max-width: 420px;
  padding: 40px 36px;
}
h1 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem; font-weight: 600;
  color: var(--purple-deep);
  margin-bottom: 6px;
  text-align: center;
}
.subtitle {
  text-align: center; color: var(--text-light);
  font-size: 0.9rem; margin-bottom: 28px;
}
label {
  display: block; font-size: 0.85rem;
  color: var(--text-light); margin-bottom: 6px; font-weight: 500;
}
input {
  width: 100%; padding: 12px 14px;
  border: 1.5px solid var(--purple-border);
  border-radius: 8px;
  font-family: 'Inter', sans-serif; font-size: 1rem;
  background: var(--purple-bg); color: var(--text);
  margin-bottom: 18px;
  transition: border-color 0.2s, box-shadow 0.2s;
}
input:focus {
  border-color: var(--purple-light);
  box-shadow: 0 0 0 3px rgba(168, 85, 199, 0.2);
}
input:focus:not(:focus-visible) {
  outline: none;
}
input:focus-visible {
  outline: 2px solid var(--purple-main);
  outline-offset: 2px;
  border-color: var(--purple-light);
  box-shadow: 0 0 0 3px rgba(168, 85, 199, 0.2);
}
button {
  width: 100%; padding: 13px;
  background: linear-gradient(135deg, var(--purple-main), var(--purple-light));
  color: var(--white); border: none; border-radius: 8px;
  font-family: 'Inter', sans-serif; font-size: 1rem; font-weight: 600;
  cursor: pointer; letter-spacing: 0.02em;
  transition: transform 0.1s, box-shadow 0.2s;
}
button:hover { transform: translateY(-1px); box-shadow: 0 4px 14px rgba(123, 45, 142, 0.3); }
button:focus-visible { outline: 2px solid var(--purple-deep); outline-offset: 3px; }
button:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.error {
  background: #fef2f2; border: 1px solid #fca5a5; color: #b91c1c;
  padding: 10px 12px; border-radius: 8px;
  font-size: 0.85rem; margin-bottom: 14px;
  display: none;
}
.error.visible { display: block; }
.error:not(:empty) { display: block; }
.ok {
  background: #f0fdf4; border: 1px solid #86efac; color: #15803d;
  padding: 10px 12px; border-radius: 8px;
  font-size: 0.88rem; margin-bottom: 14px;
}
.ok[hidden] { display: none; }
.forgot-password { text-align: center; margin-top: 18px; font-size: 0.88rem; }
.forgot-password a { color: var(--purple-main); text-decoration: none; font-weight: 500; }
.forgot-password a:hover { color: var(--purple-deep); text-decoration: underline; }
.contact-info {
  text-align: center; margin-top: 16px;
  font-size: 0.84rem; color: var(--text-light);
  background: var(--purple-bg); border: 1px solid var(--purple-border);
  border-radius: 8px; padding: 10px 14px; line-height: 1.5;
}
.contact-info a { color: var(--purple-main); font-weight: 500; white-space: nowrap; }
.contact-info a:hover { color: var(--purple-deep); text-decoration: underline; }
.version { text-align: center; color: var(--text-light); font-size: 0.75rem; margin-top: 24px; }
