:root{--primary-blue:#004AAD;--dark-blue:#002B6B;--royal-blue:#003B8E;--secondary-blue:#0057D9;--accent-yellow:#FFD700;--accent:#F6C400;--soft-yellow:#FFF6CC;--white:#FFFFFF;--page-bg:#F4F7FB;--surface:#FFFFFF;--text-dark:#1F2937;--text:#172033;--text-muted:#64748B;--muted:#64748B;--border:#E2E8F0;--danger:#DC2626;--success:#15803D;--radius:20px;--shadow:0 18px 45px rgba(15,23,42,.10)}*{box-sizing:border-box}html{background:var(--page-bg)}body{margin:0;font-family:Inter,Segoe UI,Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#F8FBFF 0%,var(--page-bg) 100%);color:var(--text);min-height:100vh}a{color:inherit;text-decoration:none}img{max-width:100%}.muted{color:var(--muted)!important}.btn,button{border:1px solid var(--border);background:var(--surface);color:var(--primary-blue);border-radius:14px;padding:.78rem 1.08rem;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:.45rem;transition:.18s ease;box-shadow:0 8px 20px rgba(15,23,42,.05)}.btn:hover,button:hover{transform:translateY(-1px);border-color:var(--primary-blue);box-shadow:0 12px 28px rgba(0,74,173,.12)}.btn.primary,button.primary{background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));color:#fff;border-color:rgba(0,74,173,.45)}.btn.gold,.btn.accent,button.gold{background:linear-gradient(135deg,var(--accent-yellow),var(--accent));color:#172033;border-color:#F2C200}.btn.light{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.30);box-shadow:none}.btn.light:hover{background:#fff;color:var(--primary-blue)}.btn.ghost{background:#fff;border-color:var(--border);color:var(--primary-blue)}.btn.danger{background:#FEF2F2;color:#B91C1C;border-color:#FECACA}.btn.small{font-size:.82rem;padding:.5rem .7rem;border-radius:12px}.btn.wide{width:100%}.alert{padding:1rem;border-radius:16px;margin:.8rem 0}.alert.success{background:#ECFDF5;border:1px solid #BBF7D0;color:#166534}.alert.danger{background:#FEF2F2;border:1px solid #FECACA;color:#991B1B}.badge{display:inline-flex;padding:.25rem .55rem;border-radius:999px;background:var(--soft-yellow);color:#664D00;font-size:.78rem;font-weight:800}.grid{display:grid;gap:1rem}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}label{display:grid;gap:.45rem;font-weight:800;color:var(--text-dark)}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:.85rem;background:#fff;color:var(--text);font:inherit;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--primary-blue);box-shadow:0 0 0 3px rgba(0,74,173,.12)}input::placeholder,textarea::placeholder{color:#94A3B8}textarea{min-height:96px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.35rem;box-shadow:var(--shadow);margin:1rem 0}.panel h2{margin:.2rem 0 1rem;font-size:1.18rem;color:var(--text-dark);letter-spacing:-.02em}.table-wrap{overflow:auto}table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;color:var(--text)}th,td{padding:.9rem;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{background:#F8FAFC;color:var(--dark-blue);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}.kpi{margin:0;min-height:128px;position:relative;overflow:hidden;background:#fff;box-shadow:0 14px 34px rgba(15,23,42,.08)}.kpi:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;background:linear-gradient(180deg,var(--accent-yellow),var(--primary-blue))}.kpi span{display:block;color:var(--muted);font-size:.87rem;font-weight:800}.kpi strong{display:block;font-size:2rem;line-height:1.1;color:var(--dark-blue);margin:.45rem 0 .25rem}.kpi small{color:var(--text-muted);font-weight:700}.filters{display:grid;grid-template-columns:repeat(6,minmax(120px,1fr));gap:.8rem;align-items:end}.print-only{display:none}.login-page{min-height:100vh;display:grid;place-items:center;padding:2rem;background:linear-gradient(135deg,var(--dark-blue),var(--primary-blue))}.login-card{max-width:460px;width:100%;background:#fff;color:var(--text);border-top:7px solid var(--accent-yellow);border-radius:22px;padding:2rem;box-shadow:0 24px 60px rgba(0,43,107,.25)}.login-card .logos{display:flex;gap:1rem;justify-content:center}.login-card .logos img{width:70px;height:70px;object-fit:contain}.login-card h1{text-align:center;color:var(--dark-blue);font-size:1.35rem}.login-card p{text-align:center;color:var(--muted)}.login-card input{background:#fff;color:var(--text);border-color:var(--border)}.footer-note{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1rem}@media(max-width:1100px){.grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.filters{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.grid.two,.grid.three,.grid.four,.filters{grid-template-columns:1fr}}@media print{body{background:#fff;color:#111}.sidebar,.topbar,.filters,.btn,.wizard-actions{display:none!important}.admin-main,.content{margin:0!important;padding:0!important;width:100%!important}.panel{box-shadow:none;border:0;color:#111;background:#fff}.print-only{display:block}table,th,td{color:#111;background:#fff;border-color:#ddd}}

/* Professional WPU Library login redesign */
.login-page.login-modern{
    min-height:100vh;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:2rem;
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 12% 18%, rgba(255,215,0,.24), transparent 28%),
        radial-gradient(circle at 88% 82%, rgba(255,255,255,.18), transparent 26%),
        linear-gradient(135deg, #002B6B 0%, #004AAD 54%, #0057D9 100%);
}
.login-page.login-modern:before,
.login-page.login-modern:after{
    content:"";
    position:absolute;
    border-radius:999px;
    pointer-events:none;
    filter:blur(.5px);
}
.login-page.login-modern:before{
    width:320px;
    height:320px;
    left:-120px;
    bottom:-150px;
    background:rgba(255,255,255,.10);
}
.login-page.login-modern:after{
    width:220px;
    height:220px;
    right:-70px;
    top:-70px;
    background:rgba(255,215,0,.16);
}
.login-shell{
    width:min(1080px,100%);
    min-height:620px;
    display:grid;
    grid-template-columns:1.03fr .97fr;
    position:relative;
    z-index:1;
    border-radius:28px;
    overflow:hidden;
    background:rgba(255,255,255,.96);
    box-shadow:0 30px 90px rgba(0,28,72,.34);
    border:1px solid rgba(255,255,255,.35);
}
.login-brand-panel{
    position:relative;
    display:flex;
    align-items:center;
    padding:3rem;
    color:#fff;
    background:
        linear-gradient(145deg, rgba(0,43,107,.98), rgba(0,74,173,.94)),
        linear-gradient(135deg, #002B6B, #004AAD);
}
.login-brand-panel:after{
    content:"";
    position:absolute;
    inset:auto 3rem 3rem 3rem;
    height:5px;
    border-radius:999px;
    background:linear-gradient(90deg,#FFD700,rgba(255,215,0,.25),transparent);
}
.login-brand-content{position:relative;z-index:1;max-width:540px}.login-logo-row{display:flex;gap:1rem;margin-bottom:2rem;align-items:center}.login-logo-wrap{width:86px;height:86px;border-radius:24px;background:rgba(255,255,255,.95);display:grid;place-items:center;padding:.65rem;box-shadow:0 18px 45px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.55)}.login-logo-wrap img{width:100%;height:100%;object-fit:contain}.login-kicker{display:inline-flex;font-size:.82rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#FFF6CC;margin-bottom:1rem}.login-brand-copy h1{margin:0;font-size:clamp(2rem,3vw,3.05rem);line-height:1.05;letter-spacing:-.045em;color:#fff}.login-brand-copy p{margin:1rem 0 0;text-align:left;color:rgba(255,255,255,.86);font-size:1rem;font-weight:700}.login-form-panel{display:flex;align-items:center;justify-content:center;padding:3rem;background:linear-gradient(180deg,#FFFFFF 0%,#F8FBFF 100%)}.login-form-card{width:100%;max-width:420px;padding:0;background:transparent;border:0;box-shadow:none}.login-form-heading{margin-bottom:1.6rem}.login-accent-line{display:block;width:64px;height:5px;border-radius:999px;background:linear-gradient(90deg,#FFD700,#F6C400);margin-bottom:1.05rem}.login-form-heading h2{margin:0;color:#002B6B;font-size:2rem;letter-spacing:-.035em}.login-form-heading p{margin:.4rem 0 0;color:#64748B;text-align:left;font-weight:700}.login-alert{margin:0 0 1.1rem}.login-form{display:grid;gap:.85rem}.login-form label{font-size:.88rem;color:#1F2937}.login-form input{min-height:52px;border-radius:16px;background:#fff;border:1px solid #D7E0EC;padding:.9rem 1rem}.login-form input:focus{border-color:#004AAD;box-shadow:0 0 0 4px rgba(0,74,173,.12)}.password-field{display:flex;align-items:center;position:relative}.password-field input{padding-right:5rem}.password-toggle{position:absolute;right:.45rem;min-width:64px;min-height:40px;padding:.45rem .7rem;border-radius:12px;border:0;background:#EEF4FF;color:#004AAD;box-shadow:none;font-weight:900}.password-toggle:hover{transform:none;background:#E1ECFF;border:0;box-shadow:none}.login-submit{width:100%;min-height:52px;margin-top:.45rem;border-radius:16px;font-size:.98rem}.login-submit:disabled{opacity:.78;cursor:wait;transform:none}.login-footer-note{text-align:center;color:#64748B;font-size:.84rem;font-weight:700;margin-top:1.25rem}.login-card{max-width:none;background:transparent;border:0;box-shadow:none;padding:0}
@media(max-width:900px){
    .login-page.login-modern{padding:1rem;align-items:flex-start;overflow:auto}.login-shell{grid-template-columns:1fr;min-height:auto}.login-brand-panel{padding:2rem}.login-brand-panel:after{left:2rem;right:2rem;bottom:1.5rem}.login-form-panel{padding:2rem}.login-logo-wrap{width:70px;height:70px;border-radius:20px}.login-brand-copy h1{font-size:1.8rem}.login-brand-copy p{font-size:.93rem}
}
@media(max-width:560px){
    .login-page.login-modern{padding:.75rem}.login-shell{border-radius:22px}.login-brand-panel{padding:1.4rem}.login-form-panel{padding:1.4rem}.login-logo-row{gap:.7rem;margin-bottom:1.25rem}.login-logo-wrap{width:58px;height:58px;border-radius:17px}.login-kicker{font-size:.7rem}.login-brand-copy h1{font-size:1.42rem}.login-form-heading h2{font-size:1.55rem}.login-form input,.login-submit{min-height:50px}
}

/* Uploaded University and Library logos on login page */
.login-logo-wrap img{object-fit:contain}.login-authorized-badge{display:inline-flex;margin-bottom:1rem;border:1px solid rgba(255,215,0,.45);background:rgba(255,215,0,.12);color:#FFF6CC;border-radius:999px;padding:.45rem .75rem;font-size:.76rem;font-weight:950;letter-spacing:.06em;text-transform:uppercase}
