/**
 * Login Page Styles
 */

.login-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: linear-gradient(135deg, var(--color-primary-50) 0%, var(--color-marble) 100%);
}

@media (min-width: 768px) {
  .login-page {
    flex-direction: row;
  }
}

/* ========================================
   Brand Panel (Desktop)
   ======================================== */
.login-brand {
  display: none;
  background: linear-gradient(135deg, var(--color-primary-400) 0%, var(--color-primary-600) 100%);
  padding: var(--space-12);
  color: white;
  position: relative;
  overflow: hidden;
}

@media (min-width: 768px) {
  .login-brand {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 45%;
    min-height: 100vh;
  }
}

.login-brand__content {
  position: relative;
  z-index: 1;
  max-width: 400px;
}

.login-brand__logo {
  width: 120px;
  height: auto;
  margin-bottom: var(--space-8);
  border-radius: var(--radius-lg);
}

.login-brand__title {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-4);
  letter-spacing: 0.5px;
}

.login-brand__subtitle {
  font-size: var(--text-lg);
  opacity: 0.9;
  line-height: var(--leading-relaxed);
}

.login-brand__decoration {
  position: absolute;
  bottom: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
}

.login-brand__decoration--small {
  width: 200px;
  height: 200px;
  bottom: auto;
  top: 50px;
  right: 50px;
  left: auto;
}

/* ========================================
   Form Panel
   ======================================== */
.login-form-panel {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
}

@media (min-width: 768px) {
  .login-form-panel {
    padding: var(--space-12);
  }
}

.login-form-container {
  width: 100%;
  max-width: 400px;
}

/* Mobile header */
.login-mobile-header {
  text-align: center;
  margin-bottom: var(--space-8);
}

@media (min-width: 768px) {
  .login-mobile-header {
    display: none;
  }
}

.login-mobile-logo {
  width: 80px;
  height: auto;
  margin-bottom: var(--space-4);
  border-radius: var(--radius-lg);
}

.login-mobile-title {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-1);
}

.login-mobile-subtitle {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

/* ========================================
   Login Card
   ======================================== */
.login-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-xl);
}

@media (min-width: 768px) {
  .login-card {
    padding: var(--space-10);
  }
}

.login-card__title {
  font-size: var(--text-2xl);
  font-weight: var(--font-semibold);
  color: var(--color-gray-900);
  margin-bottom: var(--space-2);
  display: none;
}

@media (min-width: 768px) {
  .login-card__title {
    display: block;
  }
}

.login-card__subtitle {
  font-size: var(--text-sm);
  color: var(--color-gray-500);
  margin-bottom: var(--space-8);
  display: none;
}

@media (min-width: 768px) {
  .login-card__subtitle {
    display: block;
  }
}

/* ========================================
   Login Form
   ======================================== */
.login-form {
  margin-bottom: var(--space-6);
}

.login-form .form-group {
  margin-bottom: var(--space-6);
}

.login-form .form-input {
  height: 48px;
  font-size: var(--text-base);
}

.login-form .btn {
  height: 48px;
  font-size: var(--text-base);
}

/* Error alert */
.login-error {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-error-light);
  border: 1px solid var(--color-error);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-6);
  color: var(--color-error);
  font-size: var(--text-sm);
}

.login-error__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

/* Footer */
.login-footer {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-gray-500);
}

.login-footer__legal {
  margin-top: var(--space-3);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.login-footer__legal a {
  color: var(--color-gray-500);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.login-footer__legal a:hover {
  color: var(--color-primary-600);
  text-decoration: underline;
}

.login-footer__divider {
  color: var(--color-gray-300);
}

/* Password visibility toggle */
.password-input-wrapper {
  position: relative;
}

.password-toggle-btn {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--color-gray-400);
  cursor: pointer;
  padding: var(--space-1);
  display: flex;
  align-items: center;
  justify-content: center;
}

.password-toggle-btn:hover {
  color: var(--color-gray-600);
}

.password-toggle-btn svg {
  width: 20px;
  height: 20px;
}
