/* ==========================================
   HTMX & GLOBAL STATE
   ========================================== */
.htmx-indicator {
  display: none;
}

.htmx-request .htmx-indicator {
  display: inline-block;
}

.htmx-request .button-text {
  display: none;
}

button[disabled] {
  opacity: 0.8;
  cursor: not-allowed;
}

/* ==========================================
   LAYOUT
   ========================================== */
.login-container {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4); /* 16px */
  min-height: 100vh; /* Ensures vertical centering on page */
}

.card {
  overflow: hidden;
  width: 100%;
  max-width: 650px;
  margin: 0 auto;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-default);
}

.cursor-pointer {
  cursor: pointer;
}

/* ==========================================
   FORMS & INPUTS
   ========================================== */
.input-group-text {
  background-color: transparent;
  border-color: var(--border-default);
  padding: var(--space-3) var(--space-4);
}

.form-control {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base-minus); /* 16px default */
  font-family: var(--font-primary);
  border-color: var(--border-default);
  transition: all var(--transition-base);
}

.form-control:focus {
  box-shadow: none;
  border-color: var(--border-focus);
}

.input-group:focus-within .input-group-text {
  border-color: var(--border-focus);
}

/* ==========================================
   TYPOGRAPHY
   ========================================== */
.text-center h4 {
  font-family: var(--font-primary);
  font-weight: var(--font-bold);
  font-size: var(--text-xl); /* Scales: 28px -> 20px (mobile) */
  color: var(--grey-700);
  margin-bottom: var(--space-2) !important;
}

.text-center p {
  font-family: var(--font-primary);
  font-size: var(--text-base); /* Scales: 17px -> 16px (mobile) */
  color: var(--text-secondary);
  line-height: var(--leading-body);
}

label small {
  font-size: var(--text-sm); /* 14px */
  color: var(--text-tertiary);
}

/* ==========================================
   BUTTONS & IMAGES
   ========================================== */
.btn {
  transition: all var(--transition-base);
  border-radius: var(--radius-base);
}

.btn-primary-logo:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.logo-img {
  max-width: 150px;
  width: 100%;
  height: auto;
  margin: 0 auto var(--space-4) auto;
  display: block;
}

/* ==========================================
   RESPONSIVE ADJUSTMENTS
   ========================================== */

/* Mobile (< 576px) */
@media (max-width: 576px) {
  .login-container {
    padding: var(--space-2) var(--space-1);
  }

  .card {
    box-shadow: none !important;
    border: none;
    border-radius: 0;
  }

  .card-body {
    padding: var(--space-6) var(--space-4) !important;
  }

  .logo-img {
    max-width: 100px;
  }

  .nim-btn {
    width: 100%;
    padding: var(--space-3) var(--space-4);
  }

}

/* Tablet (577px - 992px) */
@media (min-width: 577px) and (max-width: 992px) {
  .login-container {
    padding: var(--space-8) var(--space-4);
  }

  .card-body {
    padding: var(--space-12) !important;
  }
}

/* Desktop (> 993px) */
@media (min-width: 993px) {
  .card-body {
    padding: var(--space-16) !important;
  }
}