@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
.portal-body{font-family:'Inter',sans-serif;background:linear-gradient(135deg,#EEF1F8,#E8EDF8);min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;-webkit-font-smoothing:antialiased}
.portal-topbar{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:14px 32px;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);z-index:100}
.portal-topbar .brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:14px;color:#111827}
.portal-topbar .brand-text-only{font-weight:700;font-size:15px;color:#1F2937;letter-spacing:-.01em}
.portal-topbar .brand-icon{width:32px;height:32px;background:linear-gradient(135deg,#4F46E5,#6366F1);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px}
.portal-topbar .portal-brand-logo{height:34px;width:auto;max-width:180px;object-fit:contain;display:block;border-radius:6px}
.user-pill{display:flex;align-items:center;gap:8px;background:white;border:1px solid #E5E7EB;border-radius:999px;padding:5px 14px 5px 5px}
.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4F46E5,#818CF8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.user-name{font-size:13px;font-weight:600;color:#374151}
.logout-btn{background:none;border:none;color:#9CA3AF;cursor:pointer;font-size:12px;padding:4px 8px;border-radius:6px;font-family:'Inter',sans-serif;transition:all .2s}
.logout-btn:hover{background:#FEF2F2;color:#EF4444}
.portal-center{margin-top:90px;display:flex;flex-direction:column;align-items:center;width:100%}
.portal-flash-wrap{width:100%;max-width:980px;margin:0 auto 12px auto}
.portal-flash{padding:10px 14px;border-radius:10px;font-size:13px;font-weight:600;border:1px solid transparent}
.portal-flash + .portal-flash{margin-top:8px}
.portal-flash-success{background:#dcfce7;color:#166534;border-color:#86efac}
.portal-flash-error{background:#fee2e2;color:#991b1b;border-color:#fca5a5}
.portal-flash i{margin-right:6px}
.portal-hero{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:28px;max-width:480px;width:100%}
.portal-hero-logo{max-height:100px;width:auto;max-width:min(92vw,440px);height:auto;object-fit:contain;display:block;margin-bottom:14px;filter:drop-shadow(0 2px 12px rgba(15,23,42,.08))}
.portal-tagline{margin:0;font-size:15px;font-weight:700;color:#374151;letter-spacing:-.02em}
.portal-heading{font-size:38px;font-weight:800;color:#111827;text-align:center;margin-bottom:10px;line-height:1.2}
.portal-heading span{color:#4F7EF7}
.portal-subtitle{font-size:15px;color:#6B7280;text-align:center;margin-bottom:52px}
.system-cards{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;max-width:1200px;width:100%}
.system-card{display:flex;align-items:center;gap:16px;background:white;border:2px solid #E5E7EB;border-radius:16px;padding:20px 18px;width:210px;text-decoration:none;color:inherit;cursor:pointer;transition:all .28s cubic-bezier(.34,1.4,.64,1);box-shadow:0 2px 10px rgba(0,0,0,.06);position:relative}
.system-card:hover{border-color:#4F7EF7;box-shadow:0 10px 28px rgba(79,126,247,.2);transform:translateY(-4px)}
.system-card.disabled{opacity:.45;cursor:not-allowed;pointer-events:none}
.card-icon-wrap{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;flex-shrink:0;box-shadow:0 4px 12px rgba(0,0,0,.15)}
.card-content{flex:1;min-width:0}
.card-content h3{font-size:13.5px;font-weight:700;color:#111827;margin-bottom:4px;line-height:1.3}
.card-content p{font-size:11.5px;color:#6B7280;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-arrow{color:#D1D5DB;font-size:13px;flex-shrink:0;transition:all .2s}
.system-card:hover .card-arrow{color:#4F7EF7;transform:translateX(3px)}
.alert-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;background:#EF4444;border-radius:50%}
.portal-footer{margin-top:56px;font-size:13px;color:#9CA3AF;text-align:center}
.portal-footer a{color:#4F7EF7;text-decoration:none}
.login-body{font-family:'Inter',sans-serif;background:linear-gradient(135deg,#EEF1F8,#E8EDF8);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;-webkit-font-smoothing:antialiased}
.login-card{width:100%;max-width:420px;background:white;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.12);padding:44px 40px;animation:fadeUp .5s ease}
.login-logo{text-align:center;margin-bottom:30px}
.login-logo .logo-icon{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,#4F46E5,#6366F1);border-radius:18px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;box-shadow:0 6px 20px rgba(79,70,229,.35)}
.login-brand-img-wrap{margin:0 auto 16px;text-align:center}
.login-brand-img{max-height:72px;width:auto;max-width:220px;object-fit:contain;display:inline-block}
.login-logo h1{font-size:22px;font-weight:800;color:#111827;margin-bottom:4px}
.login-logo p{font-size:13.5px;color:#6B7280}
.lf-group{margin-bottom:18px}
.lf-group label{display:block;font-size:13px;font-weight:600;color:#374151;margin-bottom:6px}
.lf-group .fc{width:100%;padding:11px 14px;border:1.5px solid #E5E7EB;border-radius:10px;font-family:'Inter',sans-serif;font-size:14px;color:#111827;outline:none;transition:all .2s}
.lf-group .fc:focus{border-color:#4F7EF7;box-shadow:0 0 0 3px rgba(79,126,247,.12)}
.btn-login{width:100%;padding:12px;background:linear-gradient(135deg,#4F46E5,#6366F1);color:white;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:6px}
.btn-login:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(79,70,229,.35)}
.login-error{background:#FEF2F2;border:1px solid #FECACA;color:#991B1B;padding:11px 14px;border-radius:10px;font-size:13px;margin-bottom:18px;text-align:center}
.btn-biometric-shortcut{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:14px;padding:12px 16px;border:2px solid #4F46E5;border-radius:10px;background:#fff;color:#4F46E5;font-family:'Inter',sans-serif;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s}
.btn-biometric-shortcut:hover{background:#EEF2FF;box-shadow:0 4px 14px rgba(79,70,229,.2)}
.login-footer{text-align:center;font-size:12px;color:#9CA3AF;margin-top:24px}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:768px){.portal-heading{font-size:26px}.system-cards{flex-direction:column;align-items:center}.system-card{width:100%;max-width:400px}.portal-topbar{padding:12px 16px}}
