/* ===== PELTIC ERP - Login Page Custom Theme ===== */

/* Full page background */
body.frappe-login-page,
body[data-path="login"] {
  background: linear-gradient(135deg, #0F172A 0%, #1a1f4e 40%, #0F172A 100%) !important;
  min-height: 100vh !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Animated background particles effect */
body.frappe-login-page::before,
body[data-path="login"]::before {
  content: '';
  position: fixed;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle at 20% 80%, rgba(0, 87, 255, 0.08) 0%, transparent 50%),
              radial-gradient(circle at 80% 20%, rgba(6, 182, 212, 0.06) 0%, transparent 50%),
              radial-gradient(circle at 50% 50%, rgba(139, 92, 246, 0.04) 0%, transparent 50%);
  animation: loginBgFloat 20s ease-in-out infinite;
  z-index: 0;
}

@keyframes loginBgFloat {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  25% { transform: translate(2%, -2%) rotate(1deg); }
  50% { transform: translate(-1%, 3%) rotate(-1deg); }
  75% { transform: translate(3%, 1%) rotate(0.5deg); }
}

/* Floating orbs */
body.frappe-login-page::after,
body[data-path="login"]::after {
  content: '';
  position: fixed;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 87, 255, 0.12), transparent 70%);
  top: -100px;
  right: -100px;
  animation: loginOrb1 15s ease-in-out infinite;
  z-index: 0;
}

@keyframes loginOrb1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-80px, 80px) scale(1.2); }
}

/* Login card */
.page-card,
.login-content.page-card {
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  box-shadow: 0 25px 80px rgba(0, 0, 0, 0.3), 0 0 1px rgba(255, 255, 255, 0.1) !important;
  padding: 20px 32px !important;
  max-width: 420px !important;
  margin: 0 auto !important;
  position: relative !important;
  z-index: 1 !important;
  animation: loginCardIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
}

@keyframes loginCardIn {
  from { opacity: 0; transform: translateY(30px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Logo section */
.page-card-head {
  text-align: center !important;
  padding: 10px 0 20px !important;
  position: relative !important;
  z-index: 1 !important;
}

.page-card-head .app-logo {
  max-height: 56px !important;
  margin-bottom: 16px !important;
  filter: drop-shadow(0 4px 12px rgba(0, 87, 255, 0.2)) !important;
  animation: loginLogoFloat 4s ease-in-out infinite !important;
}

@keyframes loginLogoFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

.page-card-head h4 {
  font-size: 20px !important;
  font-weight: 800 !important;
  color: #0F172A !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
}

/* Form inputs */
.page-card .form-control,
.page-card-body .form-control {
  border-radius: 12px !important;
  border: 2px solid #E2E8F0 !important;
  padding: 12px 16px 12px 44px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  background: rgba(248, 250, 252, 0.8) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  color: #1E293B !important;
}

.page-card .form-control:focus {
  border-color: #0057FF !important;
  box-shadow: 0 0 0 4px rgba(0, 87, 255, 0.12), 0 0 20px rgba(0, 87, 255, 0.06) !important;
  background: #FFFFFF !important;
}

.page-card .form-control::placeholder {
  color: #94A3B8 !important;
  font-weight: 400 !important;
}

/* Field icons */
.field-icon {
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  color: #94A3B8 !important;
  z-index: 2 !important;
}

.email-field, .password-field {
  position: relative !important;
}

/* Login button */
.btn-login,
.btn-primary.btn-login {
  background: linear-gradient(135deg, #0057FF, #2563EB, #0057FF) !important;
  background-size: 200% 200% !important;
  animation: loginBtnGradient 4s ease infinite !important;
  border: none !important;
  border-radius: 14px !important;
  padding: 14px 24px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  letter-spacing: 0.03em !important;
  box-shadow: 0 6px 24px rgba(0, 87, 255, 0.35) !important;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  position: relative !important;
  overflow: hidden !important;
}

@keyframes loginBtnGradient {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.btn-login:hover {
  box-shadow: 0 8px 32px rgba(0, 87, 255, 0.5), 0 0 60px rgba(0, 87, 255, 0.15) !important;
  transform: translateY(-2px) !important;
}

.btn-login:active {
  transform: translateY(0) scale(0.98) !important;
}

/* Shimmer effect on button */
.btn-login::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(
    45deg,
    transparent 40%,
    rgba(255, 255, 255, 0.15) 50%,
    transparent 60%
  );
  animation: loginBtnShimmer 3s ease-in-out infinite;
}

@keyframes loginBtnShimmer {
  0% { transform: translateX(-100%) rotate(45deg); }
  100% { transform: translateX(100%) rotate(45deg); }
}

/* Forgot password link */
.forgot-password-message a,
.sign-up-message a {
  color: #0057FF !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.forgot-password-message a:hover,
.sign-up-message a:hover {
  color: #2563EB !important;
  text-decoration: underline !important;
}

/* Sign up text */
.sign-up-message {
  color: rgba(255, 255, 255, 0.7) !important;
  font-size: 14px !important;
  margin-top: 20px !important;
  position: relative !important;
  z-index: 1 !important;
}

.sign-up-message a {
  color: #06B6D4 !important;
}

.sign-up-message a:hover {
  color: #22D3EE !important;
}

/* Toggle password show */
.toggle-password {
  position: absolute !important;
  right: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  cursor: pointer !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: #0057FF !important;
  z-index: 2 !important;
}

/* Social login buttons */
.social-login-buttons .btn {
  border-radius: 12px !important;
  border: 2px solid #E2E8F0 !important;
  font-weight: 600 !important;
  transition: all 0.3s ease !important;
}

.social-login-buttons .btn:hover {
  border-color: #0057FF !important;
  box-shadow: 0 4px 12px rgba(0, 87, 255, 0.12) !important;
}

/* Divider */
.login-divider {
  color: #94A3B8 !important;
  font-size: 13px !important;
  position: relative !important;
}

/* Page card actions */
.page-card-actions {
  padding: 0 0 8px !important;
}

/* Footer area */
.web-footer,
.footer,
footer {
  display: none !important;
}

/* Navbar on login page - hide */
body.frappe-login-page .navbar,
body[data-path="login"] .navbar {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}

body.frappe-login-page .navbar::after,
body[data-path="login"] .navbar::after {
  display: none !important;
}

/* For Signup section */
.for-signup .page-card {
  animation-delay: 0.1s !important;
}

/* PELTIC branding - replace "Frappe" text */
.page-card-head h4 {
  font-size: 0 !important;
}

.page-card-head h4::after {
  content: 'Inicia sesión en PELTIC ERP';
  font-size: 18px !important;
  display: block !important;
  color: #0F172A !important;
  font-weight: 700 !important;
}

/* For signup section title override */
.for-signup .page-card-head h4::after {
  content: 'Crea tu cuenta en PELTIC ERP' !important;
}

.for-forgot .page-card-head h4::after {
  content: 'Recuperar contraseña' !important;
}

.for-login-with-email-link .page-card-head h4::after {
  content: 'Acceder con enlace de email' !important;
}

/* Responsive */
@media (max-width: 480px) {
  .page-card,
  .login-content.page-card {
    margin: 0 12px !important;
    padding: 16px 20px !important;
    border-radius: 18px !important;
  }

  .page-card-head .app-logo {
    max-height: 44px !important;
  }
}
