@import "https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=DM+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap";@import "https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=DM+Sans:wght@400;500&display=swap";:root{--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--blue-800:#1e40af;--blue-900:#1e3a5f;--grey-50:#f8fafc;--grey-100:#f1f5f9;--grey-200:#e2e8f0;--grey-300:#cbd5e1;--grey-400:#94a3b8;--grey-500:#64748b;--grey-600:#475569;--grey-700:#334155;--grey-800:#1e293b;--grey-900:#0f172a;--bg-base:var(--grey-100);--bg-surface:#fff;--border:var(--grey-200);--text-primary:var(--grey-900);--text-secondary:var(--grey-500);--text-muted:var(--grey-400);--primary:var(--blue-600);--primary-hover:var(--blue-700);--primary-light:var(--blue-50);--success:#16a34a;--success-bg:#dcfce7;--danger:#dc2626;--danger-bg:#fee2e2;--warning:#d97706;--warning-bg:#fef3c7;--header-h:64px;--sidebar-w:230px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--font-sans:"DM Sans", sans-serif;--font-display:"Sora", sans-serif;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #0000000f, 0 2px 4px -1px #0000000a;--shadow-lg:0 10px 30px -5px #2563eb1f;--shadow-xl:0 20px 50px -10px #2563eb2e}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);line-height:1.3}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-sans);cursor:pointer}input,textarea,select{font-family:var(--font-sans)}img,svg{display:block}ul{list-style:none}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--grey-100)}::-webkit-scrollbar-thumb{background:var(--blue-200);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:var(--blue-400)}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.font-bold{font-weight:700}.badge{border-radius:20px;align-items:center;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-blue{background:var(--blue-100);color:var(--blue-700)}.badge-green{background:var(--success-bg);color:var(--success)}.badge-red{background:var(--danger-bg);color:var(--danger)}.badge-yellow{background:var(--warning-bg);color:var(--warning)}.card{background:var(--bg-surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.4rem}.divider{background:var(--border);height:1.5px;margin:1rem 0}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--radius-sm)}.login-root{background:var(--bg-base);min-height:100vh;font-family:DM Sans,sans-serif;display:flex}.login-left{background:linear-gradient(145deg,#1e3a5f 0%,#2563eb 60%,#3b82f6 100%);justify-content:center;align-items:center;width:45%;display:flex;position:relative;overflow:hidden}.login-left__inner{z-index:2;max-width:420px;padding:3rem;position:relative}.login-left__blob{opacity:.12;pointer-events:none;border-radius:50%;position:absolute}.blob-1{background:#fff;width:380px;height:380px;top:-100px;right:-120px}.blob-2{background:#bfdbfe;width:260px;height:260px;bottom:-80px;left:-80px}.brand-logo{align-items:center;gap:10px;margin-bottom:3.5rem;display:flex}.brand-logo__icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #ffffff40;border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.brand-logo__name{color:#fff;letter-spacing:-.3px;font-family:Sora,sans-serif;font-size:1.5rem;font-weight:700}.login-left__copy h1{color:#fff;margin:0 0 .75rem;font-family:Sora,sans-serif;font-size:2.4rem;font-weight:700;line-height:1.2}.login-left__copy p{color:#ffffffbf;margin:0 0 2.5rem;font-size:1rem;line-height:1.65}.login-left__features{flex-direction:column;gap:.75rem;display:flex}.feature-pill{color:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff1a;border:1px solid #ffffff2e;border-radius:40px;align-items:center;gap:10px;width:fit-content;padding:.55rem 1rem;font-size:.875rem;display:flex}.feature-pill__icon{font-size:1rem;line-height:1}.login-right{background:var(--bg-base,#f1f5f9);flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;width:100%;max-width:420px;padding:2.75rem 2.5rem;box-shadow:0 4px 6px -1px #0000000f,0 20px 40px -10px #2563eb1a}.login-card__header{margin-bottom:2rem}.login-card__header h2{color:#0f172a;margin:0 0 .4rem;font-family:Sora,sans-serif;font-size:1.75rem;font-weight:700}.login-card__header p{color:#64748b;margin:0;font-size:.9rem}.login-form{flex-direction:column;gap:1.25rem;display:flex}.field-group{flex-direction:column;gap:.45rem;display:flex}.field-group label{color:#374151;justify-content:space-between;align-items:center;font-size:.83rem;font-weight:500;display:flex}.forgot-link{color:#2563eb;font-size:.8rem;font-weight:400;text-decoration:none;transition:color .15s}.forgot-link:hover{color:#1d4ed8;text-decoration:underline}.input-wrapper{position:relative}.input-icon{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.input-wrapper input{color:#0f172a;box-sizing:border-box;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;width:100%;padding:.72rem 1rem .72rem 2.5rem;font-family:DM Sans,sans-serif;font-size:.9rem;transition:border-color .2s,box-shadow .2s,background .2s}.input-wrapper input::placeholder{color:#b0bcc8}.input-wrapper input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.remember-row{margin-top:-.25rem}.checkbox-label{color:#475569;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:.85rem;display:flex}.checkbox-label input[type=checkbox]{accent-color:#2563eb;cursor:pointer;width:16px;height:16px}.btn-signin{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:.25rem;padding:.8rem 1.5rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .2s,opacity .2s;display:flex;box-shadow:0 4px 14px #2563eb59}.btn-signin:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #2563eb73}.btn-signin:active:not(:disabled){transform:translateY(0)}.btn-signin.loading{opacity:.8;cursor:not-allowed}.spinner{border:2.5px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-card__footer{text-align:center;color:#64748b;margin:1.5rem 0 0;font-size:.85rem}.login-card__footer a{color:#2563eb;font-weight:500;text-decoration:none}.login-card__footer a:hover{text-decoration:underline}@media (width<=768px){.login-root{flex-direction:column}.login-left{width:100%;min-height:220px;padding:2rem 1.5rem}.login-left__copy h1{font-size:1.75rem}.login-left__features{display:none}.login-card{padding:2rem 1.5rem}}.login-error{color:#dc2626;background:#fef2f2;border:1.5px solid #fecaca;border-radius:9px;align-items:center;gap:8px;padding:.65rem .9rem;font-size:.84rem;font-weight:500;animation:.35s shake;display:flex}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.brand-logo{justify-content:center;align-items:center;margin-top:1rem;margin-bottom:2.5rem;display:flex}.brand-logo__img{object-fit:contain;width:auto;height:60px}.sidebar{background:#fff;border-right:1px solid #e5e7eb;flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow-y:auto;box-shadow:1px 0 4px #0000000a}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:20px 10px 10px;display:flex}.nav-group{margin-bottom:4px}.nav-group__label{color:#b0b8c8;text-transform:uppercase;letter-spacing:1px;padding:10px 12px 5px;font-size:9.5px;font-weight:700;display:block}.nav-item{color:#4b5563;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 12px;font-size:13px;font-weight:400;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.nav-item:hover{color:#1e293b;background:#f1f5f9}.nav-item--active{color:#1d4ed8;background:#eff6ff;font-weight:500}.nav-item--active:before{content:"";background:#2563eb;border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:20%;left:0}.nav-item__icon{color:inherit;opacity:.85;flex-shrink:0;align-items:center;display:flex}.nav-item__label{flex:1;line-height:1}.nav-badge{color:#1e40af;letter-spacing:.3px;background:#dbeafe;border-radius:20px;align-items:center;padding:2px 8px;font-size:9.5px;font-weight:600;display:inline-flex}.nav-badge--new{color:#166534;background:#dcfce7}.dropdown{max-height:0;transition:max-height .25s;overflow:hidden}.dropdown--open{max-height:300px}.dropdown-item{color:#6b7280;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:7px;align-items:center;gap:8px;width:100%;padding:7px 12px 7px 36px;font-size:12.5px;font-weight:400;transition:background .15s,color .15s;display:flex}.dropdown-item:hover{color:#1e293b;background:#f1f5f9}.dropdown-item--active{color:#1d4ed8;background:#eff6ff;font-weight:500}.dropdown-item__icon{color:inherit;opacity:.75;flex-shrink:0;align-items:center;display:flex}.sidebar__footer{background:#f8fafc;border:1px solid #e9edf2;border-radius:10px;flex-direction:column;align-items:center;gap:0;margin:10px;padding:14px 16px;display:flex}.sidebar__credit{color:#334155;letter-spacing:.08em;text-align:center;text-transform:uppercase;margin:0;font-size:10.5px;font-weight:700;line-height:1.8}.sidebar__credit--muted{color:#94a3b8;letter-spacing:.02em;text-transform:none;text-align:center;border-top:1px dashed #e2e8f0;width:100%;margin-top:6px;padding-top:8px;font-size:9.5px;font-weight:400;line-height:1.6}.sidebar__credit--email{color:#2563eb;letter-spacing:.01em;margin-top:3px;font-size:9.5px;font-weight:500;text-decoration:none;transition:color .15s}.sidebar__credit--email:hover{color:#1d4ed8;text-decoration:underline}.header{background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:56px;padding:0 1.5rem;display:flex}.header-logo-img{width:auto;height:56px}.header-right{align-items:center;gap:12px;display:flex}.header-user{align-items:center;gap:10px;display:flex}.header-avatar{color:#534ab7;background:#eeedfe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:500;display:flex}.header-user-info{flex-direction:column;line-height:1.3;display:flex}.header-username{color:#111827;font-size:13px;font-weight:500}.header-dept{color:#6b7280;font-size:11px}.header-logout{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #e5e7eb;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:background .15s,color .15s;display:flex}.header-logout:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.app-container{background:#f3f4f6;flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-body{flex:1;display:flex;overflow:hidden}.main-content{background:#f3f4f6;flex:1;overflow-y:auto}
