:root {
    --kpra-green-dark: #0b3d22;
    --kpra-green-mid: #146c3a;
    --kpra-green-light: #1f8f4e;
    --kpra-green-accent: #9cd159;
    --login-radius: 14px;
    --login-shadow: 0 16px 48px rgba(11, 61, 34, 0.12);
    --login-input-bg: #f3f6f4;
    --login-gradient: linear-gradient(145deg, var(--kpra-green-dark) 0%, var(--kpra-green-mid) 48%, var(--kpra-green-light) 100%);
}
* { box-sizing: border-box; }
body.login-page {
    min-height: 100vh;
    margin: 0;
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
    background: #eef2ef;
    color: #1f2937;
}
.login-brand {
    position: relative;
    min-height: 300px;
    padding: 2.5rem 1.75rem;
    background: var(--login-gradient);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
@media (min-width: 992px) {
    .login-brand { min-height: 100vh; padding: 3rem 2.5rem; }
}
.login-brand::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(rgba(255, 255, 255, 0.11) 1px, transparent 1px);
    background-size: 20px 20px;
}
.login-brand::after {
    content: '';
    position: absolute;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(156, 209, 89, 0.12);
    top: -120px;
    right: -100px;
}
.login-brand-inner { position: relative; z-index: 1; max-width: 540px; text-align: center; }
.login-brand-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.85rem;
    margin-bottom: 1.25rem;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.login-brand-icon {
    width: 88px;
    height: 88px;
    border-radius: var(--login-radius);
    background: rgba(255,255,255,0.14);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
    box-shadow: 0 10px 28px rgba(0,0,0,0.18);
    font-size: 2.6rem;
    color: var(--kpra-green-accent);
}
.login-brand h1 { font-size: clamp(1.6rem, 4vw, 2.15rem); font-weight: 700; line-height: 1.2; margin-bottom: 0.65rem; }
.tagline { font-size: 1.02rem; color: rgba(255,255,255,0.9); line-height: 1.55; }
.tagline-sub { font-size: 0.9rem; color: rgba(255,255,255,0.72); margin-bottom: 1.75rem; }
.feature-strip { display: flex; flex-wrap: wrap; gap: 0.65rem; justify-content: center; }
.feature-card {
    flex: 1 1 120px;
    min-width: 118px;
    max-width: 168px;
    padding: 0.8rem 0.7rem;
    border-radius: var(--login-radius);
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
}
.feature-card i { font-size: 1.45rem; display: block; margin-bottom: 0.4rem; color: var(--kpra-green-accent); }
.feature-card .label { font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; }
.login-form-panel { display: flex; align-items: center; justify-content: center; padding: 2rem 1.25rem 2.5rem; }
@media (min-width: 992px) {
    .login-form-panel { min-height: 100vh; padding: 2rem; }
}
.login-card {
    width: 100%;
    max-width: 440px;
    padding: 2rem 1.85rem;
    background: #fff;
    border-radius: var(--login-radius);
    box-shadow: var(--login-shadow);
    border: 1px solid rgba(11,61,34,0.06);
}
.login-card-header { display: flex; align-items: center; gap: 0.85rem; margin-bottom: 1.5rem; }
.mini-icon {
    width: 46px;
    height: 46px;
    border-radius: 11px;
    background: linear-gradient(135deg, rgba(11,61,34,0.1), rgba(31,143,78,0.14));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--kpra-green-mid);
    font-size: 1.35rem;
}
.login-card h2 { font-size: 1.38rem; font-weight: 700; margin: 0; }
.subtext { font-size: 0.92rem; color: #6b7280; margin: 0.2rem 0 0; }
.form-label-caps { font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; color: #6b7280; margin-bottom: 0.4rem; }
.login-card .form-control {
    border-radius: 10px;
    border: 1px solid #dde5df;
    background: var(--login-input-bg);
    padding: 0.72rem 0.95rem;
}
.login-card .form-control:focus {
    border-color: var(--kpra-green-mid);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(20,108,58,0.16);
}
.password-wrap { position: relative; }
.password-wrap .form-control { padding-right: 2.9rem; }
.password-toggle {
    position: absolute;
    right: 0.4rem;
    top: 50%;
    transform: translateY(-50%);
    border: none;
    background: transparent;
    color: #6b7280;
}
.btn-login {
    border: none;
    border-radius: 10px;
    padding: 0.82rem 1rem;
    font-weight: 600;
    background: var(--login-gradient);
    color: #fff;
}
.btn-login:hover { filter: brightness(1.07); color: #fff; }
.govt-footer {
    margin-top: 1.35rem;
    padding-top: 1rem;
    border-top: 1px solid #e8ede9;
    text-align: center;
    font-size: 0.78rem;
    color: #9ca3af;
}
.govt-footer strong { color: var(--kpra-green-mid); }
