@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:56px;--sidebar-w:240px;--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}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}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);width:100%}img,svg{max-width:100%;height:auto;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}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-4{margin-bottom:1rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.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)}@media (width<=640px){html{font-size:15px}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.card{border-radius:var(--radius-md);padding:1rem}.p-6{padding:1rem}.p-4{padding:.75rem}}@media (width>=1280px){.card{padding:1.5rem 1.75rem}}.container{max-width:1280px;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (width>=640px){.container{padding-left:1.5rem;padding-right:1.5rem}}@media (width>=1024px){.container{padding-left:2rem;padding-right:2rem}}.form-group{margin-bottom:1.25rem}label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.9rem;font-weight:500;display:block}input,textarea,select{border:1.5px solid var(--border);border-radius:var(--radius-md);background:var(--bg-surface);padding:.75rem 1rem;font-size:1rem;transition:all .2s}input:focus,textarea:focus,select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb26}textarea{resize:vertical;min-height:120px}.form-grid{grid-template-columns:1fr;gap:1.25rem;display:grid}@media (width>=768px){.form-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.form-grid{grid-template-columns:repeat(3,1fr)}}.btn{border-radius:var(--radius-md);border:none;justify-content:center;align-items:center;gap:.5rem;min-height:44px;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-sm{min-height:38px;padding:.5rem 1rem;font-size:.875rem}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.875rem 1rem}th{color:var(--text-secondary);background:var(--grey-50);font-weight:600}.modal{z-index:2000;background:#0f172ab3;justify-content:center;align-items:center;width:100%;height:100%;padding:1rem;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-surface);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}@media (width>=640px){.modal-content{max-width:520px}}.header{height:var(--header-h);z-index:1100;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0}.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;height:100%;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;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;flex-shrink:0;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{z-index:1200;background:#fff;border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 1.5rem;display:flex;position:relative}.header-left{align-items:center;gap:.75rem;display:flex}.header-logo-img{width:auto;height:40px}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:6px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;padding:0;transition:background .15s;display:none}.hamburger:hover{background:#f1f5f9}.hamburger__bar{transform-origin:50%;background:#374151;border-radius:2px;width:22px;height:2px;transition:transform .25s cubic-bezier(.4,0,.2,1),opacity .2s,width .2s;display:block}.hamburger--open .hamburger__bar:first-child{transform:translateY(7px)rotate(45deg)}.hamburger--open .hamburger__bar:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger--open .hamburger__bar:nth-child(3){transform:translateY(-7px)rotate(-45deg)}@media (width<=1023px){.hamburger{display:flex}}.header-right{align-items:center;gap:12px;display:flex}.header-user{cursor:pointer;border-radius:6px;align-items:center;gap:10px;padding:4px 8px;transition:background .15s;display:flex}.header-user:hover{background:#f8fafc}.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}@media (width<=400px){.header-user-info{display:none}.header{padding:0 1rem}}.profile-dropdown{z-index:1300;background:#fff;border:1px solid #e5e7eb;border-radius:8px;min-width:180px;position:absolute;top:58px;right:20px;overflow:hidden;box-shadow:0 4px 12px #0000001a}.dropdown-item{text-align:left;cursor:pointer;color:#374151;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;display:flex}.dropdown-item:hover{background-color:#f8fafc}.logout-item{color:#ef4444;border-top:1px solid #e5e7eb}.logout-item:hover{color:#dc2626;background-color:#fef2f2}.app-container{background:#f3f4f6;flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.main-content{background:#f3f4f6;flex:1;overflow-y:auto}.sidebar-wrapper{flex-shrink:0;display:flex}@media (width<=1023px){.sidebar-wrapper{z-index:1100;width:240px;height:calc(100vh - 56px);transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s;position:fixed;top:56px;left:0;overflow:hidden;transform:translate(-100%)}.sidebar-wrapper--open{transform:translate(0);box-shadow:4px 0 24px #00000026}.main-content{margin-left:0!important}}.sidebar-overlay{display:none}@media (width<=1023px){.sidebar-overlay{z-index:1050;opacity:0;pointer-events:none;background:#0f172a73;transition:opacity .28s;display:block;position:fixed;inset:56px 0 0}.sidebar-overlay--visible{opacity:1;pointer-events:all}}
