/* Auth and app page styles */
:root {
  --void: #080810;
  --void-2: #0d0d1a;
  --void-3: #12122a;
  --magenta: #FF2D78;
  --magenta-dim: rgba(255,45,120,0.15);
  --cyan: #00F5FF;
  --cyan-dim: rgba(0,245,255,0.12);
  --purple: #9B5DE5;
  --text: #e8e8f0;
  --text-dim: #7a7a99;
  --font-head: 'Rajdhani', sans-serif;
  --font-mono: 'Space Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { background: var(--void); color: var(--text); font-family: var(--font-head); overflow-x: hidden; }
body::before {
  content: ''; position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(0,245,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,245,255,0.03) 1px, transparent 1px);
  background-size: 60px 60px; pointer-events: none; z-index: 0;
}

/* Auth page */
.auth-page {
  position: relative; z-index: 1;
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  padding: 2rem;
}
.auth-card {
  width: 100%; max-width: 420px;
  background: var(--void-3); border: 1px solid rgba(255,45,120,0.2);
  border-radius: 16px; padding: 2.5rem;
  box-shadow: 0 0 40px rgba(255,45,120,0.1), 0 20px 60px rgba(0,0,0,0.5);
}
.auth-header { text-align: center; margin-bottom: 2rem; }
.auth-header h1 { font-size: 2rem; font-weight: 700; color: var(--text); margin-bottom: 0.5rem; }
.auth-header p { color: var(--text-dim); font-size: 0.95rem; }
.auth-form { display: flex; flex-direction: column; gap: 1.25rem; }
.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.15em; color: var(--cyan); text-transform: uppercase; }
.form-group input {
  background: var(--void-2); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px; padding: 0.75rem 1rem; color: var(--text);
  font-family: var(--font-head); font-size: 1rem; outline: none;
  transition: border-color 0.2s;
}
.form-group input:focus { border-color: var(--magenta); box-shadow: 0 0 0 2px rgba(255,45,120,0.15); }
.label-hint { color: var(--text-dim); font-size: 0.6rem; }
.error-msg { background: rgba(255,45,120,0.1); border: 1px solid rgba(255,45,120,0.3); border-radius: 6px; padding: 0.6rem 1rem; color: var(--magenta); font-size: 0.85rem; }
.btn-primary {
  background: var(--magenta); color: #fff; border: none; border-radius: 8px;
  padding: 0.85rem; font-family: var(--font-head); font-size: 1rem; font-weight: 600;
  cursor: pointer; letter-spacing: 0.05em; transition: all 0.2s;
  box-shadow: 0 0 20px rgba(255,45,120,0.3);
}
.btn-primary:hover:not(:disabled) { background: #ff4d8c; box-shadow: 0 0 30px rgba(255,45,120,0.5); }
.btn-primary:disabled { opacity: 0.6; cursor: not-allowed; }
.auth-footer { text-align: center; margin-top: 1.5rem; font-size: 0.9rem; color: var(--text-dim); }
.auth-footer a { color: var(--magenta); text-decoration: none; font-weight: 600; }
.auth-footer a:hover { text-decoration: underline; }