/* ==========================================================
 *  VSM LOGIN PAGE - SPECIFIC STYLES
 * ========================================================== */

/* Force loading of design system on login page */
body.vsm-login-page {
  font-family: var(--vsm-font-primary, 'Poppins', 'Inter', 'SF Pro Text', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif) !important;
  background: var(--vsm-background, #ffffff) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Ensure container styles are applied */
body.vsm-login-page .vsm-container {
  min-height: 100vh !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: var(--vsm-space-lg, 24px) !important;
  background: linear-gradient(135deg, var(--vsm-secondary, #f5f5f5) 0%, var(--vsm-white, #ffffff) 100%) !important;
  position: relative !important;
}

body.vsm-login-page .vsm-container::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  background: radial-gradient(circle at 30% 20%, rgba(216, 0, 0, 0.03) 0%, transparent 50%),
              radial-gradient(circle at 70% 80%, rgba(216, 0, 0, 0.02) 0%, transparent 50%) !important;
  pointer-events: none !important;
}

/* Auth card styles */
body.vsm-login-page .vsm-auth-card {
  background: var(--vsm-white, #ffffff) !important;
  border-radius: var(--vsm-radius-lg, 20px) !important;
  box-shadow: var(--vsm-shadow-md, 0 4px 20px rgba(0,0,0,0.08)) !important;
  padding: var(--vsm-space-3xl, 48px) !important;
  width: 100% !important;
  max-width: 420px !important;
  min-width: 360px !important;
  border: 1px solid var(--vsm-border-light, #e5e7eb) !important;
  transition: var(--vsm-transition-slow, all 0.3s cubic-bezier(0.4, 0, 0.2, 1)) !important;
  position: relative !important;
  z-index: 1 !important;
}

body.vsm-login-page .vsm-auth-card:hover {
  box-shadow: var(--vsm-shadow-lg, 0 8px 32px rgba(0,0,0,0.12)) !important;
  transform: translateY(-4px) !important;
}

/* Logo styles */
body.vsm-login-page .vsm-auth-logo {
  text-align: center !important;
  margin-bottom: var(--vsm-space-lg, 24px) !important;
}

body.vsm-login-page .vsm-auth-logo img {
  width: 80px !important;
  height: 80px !important;
  border-radius: 50% !important;
  box-shadow: var(--vsm-shadow-sm, 0 2px 8px rgba(0,0,0,0.04)) !important;
  background: var(--vsm-white, #ffffff) !important;
  padding: var(--vsm-space-sm, 8px) !important;
}

/* Typography */
body.vsm-login-page .vsm-title {
  font-size: var(--vsm-font-size-3xl, 1.875rem) !important;
  font-weight: var(--vsm-font-weight-bold, 700) !important;
  color: var(--vsm-text, #111111) !important;
  margin: 0 0 var(--vsm-space-lg, 24px) 0 !important;
  text-align: center !important;
  line-height: 1.2 !important;
  letter-spacing: -0.02em !important;
}

body.vsm-login-page .vsm-subtitle {
  font-size: var(--vsm-font-size-lg, 1.125rem) !important;
  font-weight: var(--vsm-font-weight-normal, 400) !important;
  color: var(--vsm-text-light, #6b7280) !important;
  margin: 0 0 var(--vsm-space-2xl, 48px) 0 !important;
  text-align: center !important;
  line-height: 1.5 !important;
  max-width: 400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Form styles */
body.vsm-login-page .vsm-form {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--vsm-space-lg, 24px) !important;
}

body.vsm-login-page .vsm-form-group {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--vsm-space-sm, 8px) !important;
}

body.vsm-login-page .vsm-label {
  font-size: var(--vsm-font-size-sm, 0.875rem) !important;
  font-weight: var(--vsm-font-weight-medium, 500) !important;
  color: var(--vsm-text, #111111) !important;
  margin: 0 !important;
  transition: var(--vsm-transition, all 0.2s cubic-bezier(0.4, 0, 0.2, 1)) !important;
}

body.vsm-login-page .vsm-input {
  width: 100% !important;
  padding: var(--vsm-space-md, 16px) !important;
  border: 2px solid var(--vsm-border, #d1d5db) !important;
  border-radius: var(--vsm-radius-md, 12px) !important;
  font-size: var(--vsm-font-size-base, 1rem) !important;
  font-family: var(--vsm-font-primary, 'Poppins', 'Inter', 'SF Pro Text', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif) !important;
  background: var(--vsm-white, #ffffff) !important;
  color: var(--vsm-text, #111111) !important;
  transition: var(--vsm-transition-slow, all 0.3s cubic-bezier(0.4, 0, 0.2, 1)) !important;
  outline: none !important;
  box-sizing: border-box !important;
}

body.vsm-login-page .vsm-input:focus {
  border-color: var(--vsm-primary, #d80000) !important;
  box-shadow: 0 0 0 4px rgba(216, 0, 0, 0.1) !important;
  transform: translateY(-1px) !important;
}

body.vsm-login-page .vsm-input:hover:not(:focus) {
  border-color: var(--vsm-primary-hover, #b10000) !important;
  transform: translateY(-1px) !important;
}

body.vsm-login-page .vsm-input::placeholder {
  color: var(--vsm-text-muted, #9ca3af) !important;
  transition: var(--vsm-transition, all 0.2s cubic-bezier(0.4, 0, 0.2, 1)) !important;
}

body.vsm-login-page .vsm-input:focus::placeholder {
  color: var(--vsm-text-light, #6b7280) !important;
}

/* Button styles */
body.vsm-login-page .vsm-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: var(--vsm-space-md, 16px) var(--vsm-space-xl, 32px) !important;
  border: none !important;
  border-radius: var(--vsm-radius-full, 9999px) !important;
  font-size: var(--vsm-font-size-base, 1rem) !important;
  font-weight: var(--vsm-font-weight-semibold, 600) !important;
  font-family: var(--vsm-font-primary, 'Poppins', 'Inter', 'SF Pro Text', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif) !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: var(--vsm-transition-slow, all 0.3s cubic-bezier(0.4, 0, 0.2, 1)) !important;
  min-height: 48px !important;
  gap: var(--vsm-space-sm, 8px) !important;
  position: relative !important;
  overflow: hidden !important;
}

body.vsm-login-page .vsm-btn-primary {
  background: var(--vsm-primary, #d80000) !important;
  color: var(--vsm-white, #ffffff) !important;
  box-shadow: 0 4px 12px rgba(216, 0, 0, 0.3) !important;
}

body.vsm-login-page .vsm-btn-primary:hover:not(:disabled) {
  background: var(--vsm-primary-hover, #b10000) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 20px rgba(216, 0, 0, 0.4) !important;
}

body.vsm-login-page .vsm-btn-full {
  width: 100% !important;
}

/* Alert styles */
body.vsm-login-page .vsm-alert {
  padding: var(--vsm-space-md, 16px) !important;
  border-radius: var(--vsm-radius-md, 12px) !important;
  margin-bottom: var(--vsm-space-lg, 24px) !important;
  font-size: var(--vsm-font-size-sm, 0.875rem) !important;
  font-weight: var(--vsm-font-weight-medium, 500) !important;
}

body.vsm-login-page .vsm-alert-error {
  background: #fef2f2 !important;
  color: #dc2626 !important;
  border: 1px solid #fecaca !important;
}

/* Text styles */
body.vsm-login-page .vsm-text-center {
  text-align: center !important;
}

body.vsm-login-page .vsm-text-muted {
  color: var(--vsm-text-muted, #9ca3af) !important;
}

body.vsm-login-page .vsm-mt-lg {
  margin-top: var(--vsm-space-lg, 24px) !important;
}

body.vsm-login-page .vsm-mb-lg {
  margin-bottom: var(--vsm-space-lg, 24px) !important;
}

/* Link styles */
body.vsm-login-page a {
  color: var(--vsm-primary, #d80000) !important;
  text-decoration: none !important;
  font-weight: var(--vsm-font-weight-medium, 500) !important;
  transition: var(--vsm-transition, all 0.2s cubic-bezier(0.4, 0, 0.2, 1)) !important;
}

body.vsm-login-page a:hover {
  color: var(--vsm-primary-hover, #b10000) !important;
  text-decoration: underline !important;
}

/* Password toggle button */
body.vsm-login-page .vsm-pass-toggle {
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: none !important;
  border: none !important;
  color: var(--vsm-text-muted, #9ca3af) !important;
  cursor: pointer !important;
  font-size: 18px !important;
  padding: 4px !important;
  border-radius: 4px !important;
  transition: var(--vsm-transition, all 0.2s cubic-bezier(0.4, 0, 0.2, 1)) !important;
}

body.vsm-login-page .vsm-pass-toggle:hover {
  color: var(--vsm-primary, #d80000) !important;
  background: rgba(216, 0, 0, 0.1) !important;
}

/* Mobile Responsive Design */
@media (max-width: 768px) {
  body.vsm-login-page {
    padding: 16px !important;
    min-height: 100vh !important;
  }
  
  body.vsm-login-page .vsm-container {
    max-width: 100% !important;
    padding: 0 !important;
  }
  
  body.vsm-login-page .vsm-auth-card {
    padding: 24px 20px !important;
    margin: 0 !important;
    border-radius: 20px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15) !important;
  }
  
  body.vsm-login-page .vsm-title {
    font-size: 1.75rem !important;
    margin-bottom: 8px !important;
  }
  
  body.vsm-login-page .vsm-subtitle {
    font-size: 0.95rem !important;
    margin-bottom: 32px !important;
  }
  
  body.vsm-login-page .vsm-form-group {
    margin-bottom: 20px !important;
  }
  
  body.vsm-login-page .vsm-label {
    font-size: 0.9rem !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    display: block !important;
  }
  
  body.vsm-login-page .vsm-input {
    width: 100% !important;
    min-height: 52px !important;
    padding: 16px 20px !important;
    font-size: 16px !important; /* Previene zoom su iOS */
    border-radius: 12px !important;
    border: 2px solid #e5e7eb !important;
    background: white !important;
    transition: all 0.2s ease !important;
  }
  
  body.vsm-login-page .vsm-input:focus {
    border-color: var(--vsm-primary, #d80000) !important;
    box-shadow: 0 0 0 3px rgba(216, 0, 0, 0.1) !important;
    outline: none !important;
  }
  
  body.vsm-login-page .vsm-btn {
    width: 100% !important;
    min-height: 56px !important;
    padding: 18px 24px !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    border-radius: 12px !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
  }
  
  body.vsm-login-page .vsm-btn-primary {
    background: linear-gradient(135deg, var(--vsm-primary, #d80000), #ef4444) !important;
    color: white !important;
    box-shadow: 0 4px 16px rgba(216, 0, 0, 0.3) !important;
  }
  
  body.vsm-login-page .vsm-btn-primary:hover:not(:disabled) {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(216, 0, 0, 0.4) !important;
  }
  
  body.vsm-login-page .vsm-btn-secondary {
    background: linear-gradient(135deg, #6b7280, #9ca3af) !important;
    color: white !important;
    box-shadow: 0 4px 16px rgba(107, 114, 128, 0.3) !important;
  }
  
  body.vsm-login-page .vsm-btn-secondary:hover:not(:disabled) {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(107, 114, 128, 0.4) !important;
  }
  
  body.vsm-login-page .vsm-btn:disabled {
    opacity: 0.6 !important;
    cursor: not-allowed !important;
    transform: none !important;
  }
  
  /* Password toggle mobile */
  body.vsm-login-page .vsm-pass-toggle {
    right: 16px !important;
    font-size: 20px !important;
    padding: 8px !important;
    border-radius: 8px !important;
  }
  
  /* Form toggle mobile */
  body.vsm-login-page .vsm-form-toggle {
    padding: 12px 20px !important;
    font-size: 0.95rem !important;
    border-radius: 10px !important;
    margin-top: 16px !important;
  }
  
  /* Alert mobile */
  body.vsm-login-page .vsm-alert {
    padding: 16px 20px !important;
    border-radius: 12px !important;
    margin-bottom: 20px !important;
    font-size: 0.9rem !important;
  }
  
  /* Links mobile */
  body.vsm-login-page a {
    font-size: 0.9rem !important;
    padding: 8px 0 !important;
  }
}

/* Tablet */
@media (min-width: 769px) and (max-width: 1024px) {
  body.vsm-login-page {
    padding: 24px !important;
  }
  
  body.vsm-login-page .vsm-auth-card {
    padding: 32px 28px !important;
    max-width: 480px !important;
  }
  
  body.vsm-login-page .vsm-input {
    min-height: 48px !important;
    padding: 14px 18px !important;
  }
  
  body.vsm-login-page .vsm-btn {
    min-height: 52px !important;
    padding: 16px 24px !important;
  }
}

/* Desktop */
@media (min-width: 1025px) {
  body.vsm-login-page .vsm-auth-card {
    padding: 40px 36px !important;
    max-width: 500px !important;
  }
  
  body.vsm-login-page .vsm-input {
    min-height: 44px !important;
    padding: 12px 16px !important;
  }
  
  body.vsm-login-page .vsm-btn {
    min-height: 48px !important;
    padding: 14px 24px !important;
  }
}