/* Theme CSS for APE 1.0 */

/* Global typography */
body { font-family: 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; }
html, body { height: 100%; }

/* Global variables for layout */
:root { --footer-h: 56px; }
/* Khusus halaman login: hilangkan scroll seluruh halaman */
body[data-page-login="1"] {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow: hidden; /* cegah scroll tak perlu */
}

/* Login page: full width tanpa padding & background */
.login-page {
  flex: 1 0 auto; /* isi ruang sisa di atas footer */
  box-sizing: border-box;
  padding: 0 !important; /* hilangkan padding */
  margin: 0 !important;  /* hilangkan margin */
  width: 100vw;          /* lebar penuh */
  background: none !important; /* hapus background-color/image */
  display: flex;
  justify-content: center;
  align-items: center;
}

.login-card {
  width: min(100vw, 720px);
  max-height: calc(100dvh - 2rem); /* footer dihapus pada login, pastikan card tidak overflow */
  background: transparent; /* remove white background */
  border-radius: 16px;
  overflow: hidden;
}

.login-header {
  background: none !important; /* hilangkan latar emas */
  padding: 1rem; /* gunakan unit relatif, tetap rapi */
}
.brand-mark {
  width: 64px; height: 64px;
  line-height: 64px;
  border-radius: 8px;
  background: #00000077;
  color: #fff;
  font-weight: 700;
  letter-spacing: .5px;
  font-size: 16px;
}
.brand-title {
  font-weight: 800; /* bold */
  font-size: clamp(28px, 4vw, 42px);
  letter-spacing: .5px;
  color: #222;
}
.brand-sub {
  font-size: clamp(13px, 1.6vw, 16px);
  font-weight: 700; /* bold */
  color: #333;
  opacity: .85;
}
.login-body {
  background: transparent;
  padding: clamp(12px, 2vw, 24px);
}

/* Footer dihapus pada halaman login sesuai permintaan */

/* Tablet khusus (768px - 1024px) */
@media (min-width: 768px) and (max-width: 1024px) {
  .login-card {
    max-height: calc(100dvh - 3rem); /* lebih lega; footer tidak ada pada login */
  }
}

/* Desktop (>1024px): sticky footer dengan flexbox */
@media (min-width: 1024px) {
  body[data-page-login="1"] { min-height: 100vh; }
  .login-page { padding-bottom: 0; }
}

/* Responsive width scaling for larger, usable form on wider screens */
@media (min-width: 576px) { /* sm */
  .login-card { width: 520px; }
}
@media (min-width: 768px) { /* md */
  .login-card { width: 600px; }
}
@media (min-width: 992px) { /* lg */
  .login-card { width: 720px; }
}

.btn-login {
  background: linear-gradient(180deg, #d7bd74 0%, #c59e39 100%);
  border: none;
  color: #222;
  font-weight: 600;
  padding: .75rem 1rem;
}
.btn-login:hover { filter: brightness(1.05); }

.topbar { background: #111; }
.topbar .navbar-brand, .topbar .nav-link { color: #f2f2f2; }
.topbar .nav-link.active { color: #fff; font-weight: 600; }

/* Warna putih untuk semua teks 'EPI Auto Price Engine 1.0' yang diberi class khusus */
.epi-app-title, #brandCaption.brand-caption { color: #ffffff !important; }

/* Toggle password button inside floating form control */
.toggle-btn {
  position: absolute;
  right: .75rem;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: transparent;
  color: #6b7280;
}
.toggle-btn:hover { color: #c59e39; }

/* Optional glass effect for card if used */
.glass-card { backdrop-filter: blur(6px); }

/* Hilangkan padding container & gutter khusus halaman login untuk full width */
body[data-page-login="1"] .container-fluid { padding-left: 0 !important; padding-right: 0 !important; }
body[data-page-login="1"] .row.g-3 { --bs-gutter-x: 0; --bs-gutter-y: 0; }
body[data-page-login="1"] main.col-12 { padding: 0 !important; margin: 0 !important; }

/* Fixed width 320px untuk field dan tombol dengan fallback mobile */
.login-body form .form-floating,
.login-body form .form-control,
.login-body form .btn-login {
  width: 320px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.login-body form .form-control { padding: .75rem 1rem; margin: 0; }
.login-body form .btn-login { padding: .75rem 1rem; display: block; }

@media (max-width: 360px) {
  .login-body form .form-floating,
  .login-body form .form-control,
  .login-body form .btn-login { width: 92vw; }
}

/* Footer fixed style for login page removed per request */