/* 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 background approximating gold gradient */
.login-page {
  flex: 1 0 auto; /* isi ruang sisa di atas footer */
  box-sizing: border-box;
  padding: clamp(12px, 2.5vw, 24px);
  background: radial-gradient(1200px 600px at 50% -200px, #ffe08a 0%, #e7be4c 40%, #caa24a 70%, #b7903b 100%);
  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 {
  padding: 10px 10px 10px 10px;
}
.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(16px, 3vw, 32px);
}

/* 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: clamp(16px, 2.5vw, 32px); }
}

/* 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; }

/* 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); }

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