:root {
  --bg-body: #fafafa;
  --text-main: #0f172a;
  --text-secondary: #64748b;
  --border-light: #e2e8f0;
  --primary-dark: #18181b;
  --primary-hover: #27272a;
  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --error-bg: #fef2f2;
  --error-border: #fecaca;
  --error-text: #991b1b;
  --error-icon: #dc2626;
  --success-bg: #f0fdf4;
  --success-border: #bbf7d0;
  --success-text: #166534;
  --success-icon: #16a34a;
}

body {
  font-family: "Inter", sans-serif;
  background-color: var(--bg-body);
  color: var(--text-main);
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  -webkit-font-smoothing: antialiased;

  /* Dot Pattern Background */
  background-image: radial-gradient(#e4e4e7 1px, transparent 1px);
  background-size: 24px 24px;
}

.spor-card {
  background: #fff;
  border: 1px solid var(--border-light);
  border-radius: 16px; /* Slightly more rounded */
  box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  width: 100%;
  max-width: 400px;
  overflow: hidden;
  position: relative;
}

.form-control {
  border-radius: 8px;
  border: 1px solid var(--border-light);
  padding: 0.75rem 1rem;
  font-size: 0.95rem;
  color: var(--text-main);
  box-shadow: var(--shadow-sm);
  background-color: #fff;
}

.form-control:focus {
  border-color: var(--primary-dark);
  box-shadow: 0 0 0 2px rgba(24, 24, 27, 0.1);
}

/* Password Toggle Button */
.btn-toggle-password {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-top-right-radius: 8px;
  border-bottom-right-radius: 8px;
  border: 1px solid var(--border-light);
  border-left: none;
  background-color: #fff;
  color: var(--text-secondary);
}
.btn-toggle-password:hover {
  background-color: #f8fafc;
  color: var(--text-main);
}
.password-input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}
.password-input:focus {
  z-index: 1; /* Bring to front on focus */
}

.btn-spor-primary {
  background-color: var(--primary-dark);
  color: white;
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-weight: 500;
  font-size: 0.95rem;
  border: none;
  width: 100%;
  transition: all 0.2s;
}

.btn-spor-primary:hover {
  background-color: var(--primary-hover);
  color: white; /* Păstrează textul alb la hover */
  transform: translateY(-1px);
}

.btn-spor-primary:focus,
.btn-spor-primary:active {
  background-color: var(--primary-hover);
  color: white;
  border: none;
  box-shadow: 0 0 0 2px rgba(24, 24, 27, 0.2);
}

.logo-container {
  width: 56px;
  height: 56px;
  background: var(--primary-dark);
  color: white;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
}

/* Alert Styles */
.alert {
  border-radius: 8px;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  border: 1px solid;
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  background-color: #fff;
}

.alert i {
  font-size: 1.125rem;
  margin-top: 0.125rem;
  flex-shrink: 0;
}

.alert-title {
  font-weight: 600;
  margin-bottom: 0.25rem;
  font-size: 0.875rem;
}

.alert-message {
  font-size: 0.8125rem;
  line-height: 1.4;
}

/* Error Alert */
.alert-error {
  background-color: var(--error-bg);
  border-color: var(--error-border);
  color: var(--error-text);
}

.alert-error i {
  color: var(--error-icon);
}

.alert-error .alert-title {
  color: var(--error-text);
}

.alert-error .alert-message {
  color: var(--error-text);
  opacity: 0.9;
}

/* Success Alert */
.alert-success {
  background-color: var(--success-bg);
  border-color: var(--success-border);
  color: var(--success-text);
}

.alert-success i {
  color: var(--success-icon);
}

.alert-success .alert-title {
  color: var(--success-text);
}

.alert-success .alert-message {
  color: var(--success-text);
  opacity: 0.9;
}
