/* ============================================
   RookyNex Custom Login Page
   ============================================ */

:root {
  --rn-primary: #6C3CE1;
  --rn-primary-hover: #5A2DC5;
  --rn-primary-light: #EDE5FB;
  --rn-secondary: #1A1A2E;
  --rn-gray-50: #F9FAFB;
  --rn-gray-200: #E5E7EB;
  --rn-gray-400: #9CA3AF;
  --rn-gray-500: #6B7280;
  --rn-gray-700: #374151;
  --rn-gray-900: #111827;
  --rn-white: #FFFFFF;
  --rn-radius-sm: 0.375rem;
  --rn-radius-md: 0.5rem;
  --rn-radius-lg: 0.75rem;
  --rn-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
  --rn-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
  --rn-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

/* --- Page background --- */
body.login {
  background: var(--rn-gray-50);
  font-family: var(--rn-font-sans);
}

/* --- Logo --- */
.login h1 a {
  background-image: none !important;
  width: auto !important;
  height: auto !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0 !important;
  color: var(--rn-secondary);
  text-decoration: none;
  text-indent: 0 !important;
  margin-bottom: 1.5rem;
}

.login h1 a::before {
  content: 'R';
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--rn-primary);
  color: var(--rn-white);
  font-weight: 800;
  font-size: 1.125rem;
  border-radius: var(--rn-radius-sm);
}

.login h1 a::after {
  content: 'RookyNex';
  font-size: 1.5rem;
  font-weight: 700;
}

/* --- Login box --- */
.login form {
  background: var(--rn-white);
  border: 1px solid var(--rn-gray-200) !important;
  border-radius: var(--rn-radius-lg) !important;
  box-shadow: var(--rn-shadow-md) !important;
  padding: 2rem 2rem 1.5rem !important;
}

/* --- Labels --- */
.login form .forgetmenot label,
.login label {
  font-family: var(--rn-font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--rn-gray-700);
}

/* --- Input fields --- */
.login form input[type="text"],
.login form input[type="password"],
.login form input[type="email"] {
  font-family: var(--rn-font-sans);
  font-size: 0.95rem;
  border: 1px solid var(--rn-gray-200) !important;
  border-radius: var(--rn-radius-md) !important;
  padding: 0.625rem 0.75rem !important;
  box-shadow: none !important;
  background: var(--rn-white) !important;
  color: var(--rn-gray-900);
  transition: border-color 150ms ease-in-out, box-shadow 150ms ease-in-out;
}

.login form input[type="text"]:focus,
.login form input[type="password"]:focus,
.login form input[type="email"]:focus {
  border-color: var(--rn-primary) !important;
  box-shadow: 0 0 0 2px rgba(108, 60, 225, 0.15) !important;
  outline: none;
}

/* --- Submit button --- */
.login form .submit input[type="submit"],
.wp-core-ui .button-primary {
  font-family: var(--rn-font-sans) !important;
  background: var(--rn-primary) !important;
  border: none !important;
  border-radius: var(--rn-radius-md) !important;
  color: var(--rn-white) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  padding: 0.625rem 1.5rem !important;
  height: auto !important;
  line-height: 1.5 !important;
  text-shadow: none !important;
  box-shadow: none !important;
  cursor: pointer;
  transition: background 150ms ease-in-out;
  width: 100%;
}

.login form .submit input[type="submit"]:hover,
.login form .submit input[type="submit"]:focus,
.wp-core-ui .button-primary:hover,
.wp-core-ui .button-primary:focus {
  background: var(--rn-primary-hover) !important;
  box-shadow: none !important;
}

/* --- Remember me checkbox --- */
.login form input[type="checkbox"] {
  accent-color: var(--rn-primary);
}

/* --- Links below the form --- */
.login #nav,
.login #backtoblog {
  text-align: center;
  padding: 0.75rem 0 0;
}

.login #nav a,
.login #backtoblog a,
.login .privacy-policy-page-link a {
  font-family: var(--rn-font-sans);
  font-size: 0.875rem;
  color: var(--rn-primary);
  text-decoration: none;
  transition: color 150ms ease-in-out;
}

.login #nav a:hover,
.login #backtoblog a:hover,
.login .privacy-policy-page-link a:hover {
  color: var(--rn-primary-hover);
}

/* --- Error / info messages --- */
.login .message,
.login .success {
  font-family: var(--rn-font-sans);
  border-left: 4px solid var(--rn-primary) !important;
  border-radius: var(--rn-radius-sm);
  background: var(--rn-primary-light);
  color: var(--rn-gray-700);
  font-size: 0.875rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  box-shadow: none;
}

#login_error {
  font-family: var(--rn-font-sans);
  border-left: 4px solid #dc2626 !important;
  border-radius: var(--rn-radius-sm);
  background: #fef2f2;
  color: #991b1b;
  font-size: 0.875rem;
  padding: 0.75rem 1rem;
  box-shadow: none;
}

#login_error a {
  color: #991b1b;
  font-weight: 600;
}

/* --- Privacy policy link --- */
.login .privacy-policy-page-link {
  text-align: center;
  margin-top: 1rem;
}

/* --- Language switcher (WP 5.9+) --- */
.language-switcher {
  font-family: var(--rn-font-sans);
}

.language-switcher .button {
  border-radius: var(--rn-radius-md) !important;
}

/* --- Responsive --- */
#login {
  width: 400px !important;
  padding-top: 6vh !important;
}

@media (max-width: 480px) {
  #login {
    width: 90% !important;
    padding-top: 3vh !important;
  }

  .login form {
    padding: 1.5rem 1.25rem 1.25rem !important;
  }
}
