@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap);@import url(https://cdn.jsdelivr.net/npm/@tabler/icons-webfont@latest/tabler-icons.min.css);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--blue:#2563eb;--blue-dark:#1e40af;--blue-light:#eff6ff;--blue-mid:#3b82f6;--sidebar-w:240px;--white:#fff;--bg:#f6f9fc;--bg2:#f1f5f9;--border:#e8eef5;--border2:#e2e8f0;--text:#0a2540;--text2:#475569;--text3:#64748b;--green:#16a34a;--green-bg:#f0fdf4;--amber:#d97706;--amber-bg:#fffbeb;--red:#dc2626;--red-bg:#fef2f2;--purple:#7c3aed;--purple-bg:#f5f3ff;--teal:#0d9488;--teal-bg:#f0fdfa;--radius:16px;--radius-sm:10px;--radius-pill:100px;--shadow-sm:0 1px 3px #0a25400d;--shadow:0 8px 24px #0a254014;--shadow-md:0 20px 60px #0a25401f;--font:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--mono:"JetBrains Mono",monospace}body{-webkit-font-smoothing:antialiased;background:#eef2f7;color:#0a2540;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:14px;line-height:1.5}::-webkit-scrollbar{height:5px;width:5px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#dde3ec;border-radius:3px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{box-shadow:0 0 0 0 #0570de26;transform:scale(1)}50%{box-shadow:0 0 0 8px #0570de00;transform:scale(1.04)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes successPop{0%{opacity:0;transform:scale(.5)}60%{opacity:1;transform:scale(1.08)}to{opacity:1;transform:scale(1)}}@keyframes successRing{0%{opacity:.6;transform:scale(.8)}to{opacity:0;transform:scale(1.6)}}@keyframes taskSlideIn{0%{max-height:0;opacity:0;transform:translateX(-12px)}to{max-height:120px;opacity:1;transform:translateX(0)}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse-dot{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}.page{animation:fadeInUp .25s ease}.stat-card{animation:fadeInUp .3s ease}.card{animation:fadeInUp .28s ease}.loading-spinner-wrap{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center}.loading-spinner-wrap.loading-spinner-inline{flex-direction:row;gap:8px}.loading-spinner{animation:spin .75s linear infinite;border:3px solid #f1f5f9;border-radius:50%;border-top-color:#2563eb;border:3px solid var(--bg2);border-top-color:var(--blue)}.loading-spinner-sm .loading-spinner{border-width:2px;height:18px;width:18px}.loading-spinner-md .loading-spinner{height:32px;width:32px}.loading-spinner-lg .loading-spinner{border-width:4px;height:44px;width:44px}.loading-spinner-label{color:#64748b;color:var(--text3);font-size:13px;font-weight:500}.loading-overlay{align-items:center;animation:fadeInUp .2s ease;display:flex;justify-content:center;min-height:160px;padding:48px 24px}.loading-overlay-full{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffffd9;border-radius:inherit;inset:0;position:absolute;z-index:10}.skeleton{animation:shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#f1f5f9 25%,#e8edf3 50%,#f1f5f9 75%);background:linear-gradient(90deg,var(--bg2) 25%,#e8edf3 50%,var(--bg2) 75%);background-size:200% 100%;border-radius:6px}.btn.is-loading{opacity:.85;pointer-events:none;position:relative}.btn.is-loading .btn-spinner{animation:spin .7s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;margin-right:8px;vertical-align:-2px;width:14px}.task-row-enter{animation:taskSlideIn .45s ease forwards}.submit-success-overlay{align-items:center;animation:overlayFadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0a254059;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.submit-success-card{animation:fadeInUp .35s ease;background:#fff;background:var(--white);border-radius:16px;border-radius:var(--radius);box-shadow:0 20px 60px #0a25401f;box-shadow:var(--shadow-md);min-width:280px;padding:36px 40px;position:relative;text-align:center}.submit-success-ring{animation:successRing .8s ease-out forwards;border:3px solid #16a34a;border:3px solid var(--green);border-radius:50%;height:72px;left:50%;margin-left:-36px;position:absolute;top:28px;width:72px}.submit-success-icon{align-items:center;animation:successPop .5s cubic-bezier(.34,1.56,.64,1) forwards;background:#f0fdf4;background:var(--green-bg);border-radius:50%;color:#16a34a;color:var(--green);display:flex;font-size:32px;height:72px;justify-content:center;margin:0 auto 16px;width:72px}.submit-success-title{color:#0a2540;color:var(--text);font-size:18px;font-weight:600;margin-bottom:6px}.submit-success-sub{color:#64748b;color:var(--text3);font-size:13px}.profile-hero{align-items:center;animation:fadeInUp .35s ease;background:linear-gradient(135deg,#1e3a8a,#2563eb 55%,#3b82f6);border:none;border-radius:18px;box-shadow:0 14px 40px #2563eb47;display:flex;gap:22px;margin-bottom:20px;overflow:hidden;padding:28px 30px;position:relative}.profile-hero:before{background:#ffffff14;height:280px;right:-70px;top:-90px;width:280px}.profile-hero:after,.profile-hero:before{border-radius:50%;content:"";position:absolute}.profile-hero:after{background:#ffffff0f;bottom:-120px;height:210px;right:150px;width:210px}.profile-hero>*{position:relative;z-index:1}.profile-avatar{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff29;border:3px solid #ffffff80;border-radius:50%;box-shadow:0 8px 24px #0000002e;color:#fff;display:flex;flex-shrink:0;font-size:30px;font-weight:700;height:84px;justify-content:center;width:84px}.profile-hero-name{color:#fff;font-size:23px;font-weight:700;letter-spacing:-.4px;margin-bottom:7px}.profile-hero-meta{align-items:center;display:flex;flex-wrap:wrap;gap:14px}.profile-hero-meta>span{align-items:center;color:#ffffffe0;display:inline-flex;font-size:13px;gap:5px}.profile-hero-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff2e!important;border-radius:20px;color:#fff!important;font-size:12px;font-weight:600;padding:3px 12px}.profile-hero-last{align-items:center;color:#ffffffb8;display:flex;font-size:12px;gap:5px;margin-top:9px}.profile-hero-btn{align-items:center;background:#fff;border:none;border-radius:10px;box-shadow:0 4px 14px #00000026;color:#1e40af;cursor:pointer;display:inline-flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;font-weight:600;gap:7px;padding:9px 16px;transition:all .18s ease}.profile-hero-btn:hover{box-shadow:0 8px 20px #00000038;transform:translateY(-2px)}.profile-hero-btn.ghost{background:#ffffff26;box-shadow:none;color:#fff}.profile-hero-btn.ghost:hover{background:#ffffff42}.profile-stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}@media (max-width:900px){.profile-stats-grid{grid-template-columns:repeat(2,1fr)}}.profile-stat-card{animation:fadeInUp .4s ease backwards;background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);overflow:hidden;padding:20px 18px;position:relative;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.profile-stat-card:before{background:#0000;background:var(--accent,#0000);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.profile-stat-card:hover:before{opacity:1}.profile-stat-card:first-child{animation-delay:.05s}.profile-stat-card:nth-child(2){animation-delay:.1s}.profile-stat-card:nth-child(3){animation-delay:.15s}.profile-stat-card:nth-child(4){animation-delay:.2s}.profile-stat-card:hover{box-shadow:0 8px 24px #0a254014;box-shadow:var(--shadow);transform:translateY(-3px)}.profile-stat-icon{align-items:center;border-radius:12px;display:flex;font-size:22px;height:48px;justify-content:center;margin:0 auto 12px;width:48px}.profile-stat-value{animation:countUp .6s ease backwards;font-size:32px;font-weight:500;letter-spacing:-1px;line-height:1}.profile-stat-label{color:#64748b;color:var(--text3);font-size:12px;font-weight:500;margin-top:8px}.app-layout{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#0c1c33,#10243f);bottom:0;box-shadow:4px 0 24px #0a254026;display:flex;flex-direction:column;left:0;position:fixed;top:0;width:240px;width:var(--sidebar-w);z-index:100}.sidebar-brand{border-bottom:1px solid #ffffff0f;gap:11px;padding:20px 16px}.brand-icon,.sidebar-brand{align-items:center;display:flex}.brand-icon{background:linear-gradient(135deg,#3b82f6,#60a5fa);border-radius:10px;box-shadow:0 4px 14px #3b82f666;color:#fff;flex-shrink:0;font-size:16px;font-weight:800;height:36px;justify-content:center;width:36px}.brand-name{color:#fff;font-size:14px;font-weight:700}.brand-sub{color:#64748b;font-size:10px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 10px}.nav-section-label{color:#475569;font-size:10px;font-weight:600;letter-spacing:1px;padding:12px 10px 5px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:9px;color:#94a3b8;cursor:pointer;display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;font-weight:400;gap:11px;margin-bottom:2px;padding:9px 12px;position:relative;text-decoration:none;transition:all .15s ease;width:100%}.nav-item:hover{background:#ffffff0d;color:#e2e8f0}.nav-item.active{background:linear-gradient(135deg,#3b82f633,#3b82f614);color:#60a5fa;font-weight:600}.nav-item.active:before{background:#3b82f6;border-radius:0 3px 3px 0;bottom:6px;box-shadow:0 0 10px #3b82f6;content:"";left:-10px;position:absolute;top:6px;width:3px}.nav-icon{flex-shrink:0;font-size:17px}.nav-badge{background:#3b82f6;border-radius:9px;box-shadow:0 2px 6px #3b82f666;color:#fff;font-size:10px;font-weight:700;margin-left:auto;min-width:18px;padding:1px 7px;text-align:center}.nav-item:not(.active) .nav-badge{background:#3b82f640;box-shadow:none;color:#93c5fd}.sidebar-footer{border-top:1px solid #ffffff0f;padding:12px}.user-card{align-items:center;background:#ffffff0a;border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:9px;transition:background .15s}.user-card:hover{background:#ffffff14}.user-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;display:flex;flex-shrink:0;font-weight:700;height:34px;justify-content:center;width:34px}.user-avatar,.user-name{color:#fff;font-size:12px}.user-name{font-weight:600}.user-role{color:#64748b;font-size:10px}.logout-btn{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:16px;justify-content:center;margin-left:auto;padding:4px;transition:all .12s}.logout-btn:hover{background:#ef44441f;color:#f87171}.main-content{background:#f6f9fc;background:var(--bg);display:flex;flex:1 1;flex-direction:column;margin-left:240px;margin-left:var(--sidebar-w);min-height:100vh}.topbar{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffffd9;border-bottom:1px solid #e8eef5;display:flex;gap:12px;height:62px;padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar,.topbar-menu-btn{align-items:center;flex-shrink:0}.topbar-menu-btn{background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;display:none;font-size:20px;height:38px;justify-content:center;width:38px}.topbar-menu-btn:hover{border-color:#bfdbfe;color:#3b82f6}.sidebar-close-btn{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:none;font-size:20px;justify-content:center;margin-left:auto;padding:4px}.sidebar-close-btn:hover{color:#fff}.sidebar-overlay{background:#080f1e80;display:none;inset:0;opacity:0;position:fixed;transition:opacity .25s ease;z-index:99}.topbar-greeting{display:flex;flex-direction:column;line-height:1.2;min-width:0}.topbar-greeting-label{color:#64748b;color:var(--text3);font-size:11px;font-weight:500}.topbar-greeting-name{color:#0a2540;color:var(--text);font-size:16px;font-weight:700;letter-spacing:-.3px}.topbar-right{gap:6px;margin-left:auto}.topbar-icon-btn,.topbar-right{align-items:center;display:flex}.topbar-icon-btn{background:#fff;border:1px solid #e2e8f0;border-radius:10px;color:#475569;cursor:pointer;height:38px;justify-content:center;position:relative;transition:all .15s;width:38px}.topbar-icon-btn:hover{border-color:#bfdbfe;box-shadow:0 4px 12px #3b82f61f;color:#3b82f6;transform:translateY(-1px)}.topbar-icon-btn i{font-size:19px}.topbar-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:10px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:700;height:38px;justify-content:center;margin-left:4px;transition:transform .15s;width:38px}.topbar-avatar:hover{transform:translateY(-1px)}.notif-dot{animation:pulse-dot 2s infinite;background:#ef4444;border:2px solid #fff;border-radius:50%;height:8px;position:absolute;right:7px;top:7px;width:8px}.page{flex:1 1;max-width:1440px;padding:28px 32px}.page-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:24px}.page-title{color:#0a2540;color:var(--text);font-size:22px;font-weight:600;letter-spacing:-.4px;line-height:1.2}.page-sub{color:#64748b;color:var(--text3);font-size:13px;margin-top:4px}.btn{align-items:center;border:none;border-radius:10px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;font-weight:500;gap:7px;padding:8px 18px;transition:all .15s}.btn-primary{background:linear-gradient(180deg,#0a7af0,#2563eb);background:linear-gradient(180deg,#0a7af0,var(--blue));box-shadow:0 2px 8px #0570de47;color:#fff}.btn-primary:hover{background:linear-gradient(180deg,#2563eb,#1e40af);background:linear-gradient(180deg,var(--blue),var(--blue-dark));box-shadow:0 4px 14px #0570de61;transform:translateY(-1px)}.btn-primary:active{box-shadow:0 1px 4px #0570de33;transform:translateY(0)}.btn-ghost{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);color:#475569;color:var(--text2)}.btn-ghost:hover{background:#f6f9fc;background:var(--bg);border-color:#e2e8f0;border-color:var(--border2);color:#0a2540;color:var(--text)}.btn-danger{background:#fef2f2;background:var(--red-bg);border:1px solid #dc262626;color:#dc2626;color:var(--red)}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.card{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);margin-bottom:16px;overflow:hidden;transition:box-shadow .2s ease}.card:hover{box-shadow:0 8px 24px #0a254012}.card-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:10px;padding:16px 20px}.card-title{color:#0a2540;color:var(--text);font-size:14px;font-weight:700}.card-count{background:#f1f5f9;border-radius:10px;color:#64748b;color:var(--text3);font-size:11px;font-weight:600;padding:3px 10px}.card-actions{gap:8px}.card-actions,.view-all-link{display:flex;margin-left:auto}.view-all-link{align-items:center;background:none;border:none;color:#2563eb;color:var(--blue);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:12px;font-weight:600;gap:4px;transition:gap .2s}.view-all-link:hover{gap:7px}.stats-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.stat-card{animation:fadeInUp .4s ease backwards;background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);cursor:default;overflow:hidden;padding:18px 20px;position:relative;transition:all .2s ease}.stat-card:after{border-radius:3px 3px 0 0;content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s}.stat-card:hover{box-shadow:0 12px 28px #0a25401a;transform:translateY(-3px)}.stat-card:hover:after{opacity:1}.stat-card.stat-blue:after{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-card.stat-amber:after{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card.stat-red:after{background:linear-gradient(90deg,#ef4444,#f87171)}.stat-card.stat-green:after{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card:first-child{animation-delay:.04s}.stat-card:nth-child(2){animation-delay:.08s}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:nth-child(4){animation-delay:.16s}.stat-head{justify-content:space-between;margin-bottom:14px}.stat-head,.stat-icon{align-items:center;display:flex}.stat-icon{border-radius:12px;height:42px;justify-content:center;width:42px}.stat-icon i{font-size:20px}.stat-label{color:#64748b;color:var(--text3);font-size:12px;font-weight:500;margin-top:6px}.stat-value{color:#0a2540;color:var(--text);font-size:30px;font-weight:800;letter-spacing:-1px;line-height:1}.stat-sub{color:#64748b;color:var(--text3);font-size:11px;margin-top:5px}.welcome-banner{align-items:center;background:linear-gradient(120deg,#1e40af,#2563eb 45%,#3b82f6);border-radius:18px;box-shadow:0 12px 32px #2563eb40;display:flex;gap:18px;margin-bottom:20px;overflow:hidden;padding:24px 28px;position:relative}.welcome-banner:before{background:#ffffff14;height:280px;right:-60px;top:-80px;width:280px}.welcome-banner:after,.welcome-banner:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.welcome-banner:after{background:#ffffff0d;bottom:-100px;height:200px;right:120px;width:200px}.banner-emoji{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff2e;border-radius:14px;box-shadow:inset 0 1px 0 #fff3;display:flex;flex-shrink:0;font-size:26px;height:54px;justify-content:center;width:54px}.banner-emoji,.banner-text{position:relative;z-index:1}.banner-text h2{color:#fff;font-size:19px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}.banner-text p{color:#ffffffd9;font-size:13px}.hero-sub{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.hero-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border-radius:12px;color:#fff;font-size:11px;font-weight:600;padding:2px 10px}.banner-action,.hero-btn{background:#fff;border:none;border-radius:11px;box-shadow:0 4px 16px #00000026;color:#1e40af;cursor:pointer;flex-shrink:0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;font-weight:700;margin-left:auto;padding:11px 22px;position:relative;transition:all .2s;white-space:nowrap;z-index:1}.banner-action:hover,.hero-btn:hover{box-shadow:0 8px 24px #0003;transform:translateY(-2px)}table{border-collapse:collapse;width:100%}th{background:#fafcfe;border-bottom:1px solid #f1f5f9;color:#94a3b8;font-size:10px;font-weight:700;letter-spacing:.6px;padding:10px 16px;text-align:left;text-transform:uppercase}td{border-bottom:1px solid #f8fafc;color:#475569;color:var(--text2);font-size:13px;padding:13px 16px;transition:background .15s;vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:all .15s}tbody tr:hover{background:#f8fbff;cursor:pointer}tbody tr:hover td:first-child{box-shadow:inset 3px 0 0 #3b82f6}.td-main{color:#0a2540;color:var(--text);font-weight:600}.td-id{background:#f8fafc;border-radius:6px;color:#94a3b8;display:inline-block;font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:11px;font-weight:600;padding:3px 8px}.user-cell{align-items:center;display:flex;gap:8px}.av-sm{color:#fff;flex-shrink:0;font-size:10px;font-weight:700;height:26px;justify-content:center;width:26px}.av-sm,.badge{align-items:center;border-radius:8px;display:inline-flex}.badge{font-size:11px;font-weight:600;gap:5px;padding:4px 11px}.badge-Open{background:#eff6ff;color:#1d4ed8}.badge-In-Progress{background:#fffbeb;color:#b45309}.badge-Resolved{background:#f0fdf4;color:#15803d}.badge-Closed{background:#f1f5f9;color:#64748b}.badge-dot{border-radius:50%;height:6px;width:6px}.badge-Open .badge-dot{background:#3b82f6}.badge-In-Progress .badge-dot{background:#f59e0b}.badge-Resolved .badge-dot{background:#22c55e}.badge-Closed .badge-dot{background:#94a3b8}.chip{align-items:center;border-radius:8px;display:inline-flex;font-size:11px;font-weight:600;gap:5px;padding:4px 11px}.chip-IT{background:#eff6ff;color:#1d4ed8}.chip-HR{background:#f0fdf4;color:#15803d}.chip-Admin{background:#fffbeb;color:#b45309}.chip-Facilities{background:#f0fdfa;color:#0f766e}.priority-Critical,.priority-High,.priority-Low,.priority-Medium{font-size:12px;font-weight:600}.priority-Critical:before,.priority-High:before,.priority-Low:before,.priority-Medium:before{content:"● ";font-size:10px}.priority-Low{color:#16a34a}.priority-Medium{color:#2563eb}.priority-High{color:#d97706}.priority-Critical{color:#dc2626}.form-group{margin-bottom:16px}.form-group label{color:#475569;color:var(--text2);display:block;font-size:12px;font-weight:500;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#0a2540;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;outline:none;padding:9px 12px;transition:all .15s;width:100%}.form-group input:hover,.form-group select:hover{border-color:#e2e8f0;border-color:var(--border2)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;border-color:var(--blue);box-shadow:0 0 0 3px #0570de1a}.form-group textarea{line-height:1.6;min-height:96px;resize:vertical}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.required{color:#dc2626;color:var(--red)}.filter-bar{align-items:center;display:flex;gap:8px;margin-bottom:16px}.search-wrap{flex:1 1;position:relative}.search-icon{color:#64748b;color:var(--text3);font-size:16px;left:11px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#0a2540;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;outline:none;padding:8px 12px 8px 36px;transition:all .15s;width:100%}.search-input:focus{border-color:#2563eb;border-color:var(--blue);box-shadow:0 0 0 3px #0570de1a}.filter-select{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#475569;color:var(--text2);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;outline:none;padding:8px 12px;transition:all .15s}.filter-select:focus{border-color:#2563eb;border-color:var(--blue)}.modal-overlay{align-items:center;animation:overlayFadeIn .2s ease;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a254066;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{animation:modalIn .28s cubic-bezier(.34,1.2,.64,1);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:18px;border-radius:calc(var(--radius) + 2px);box-shadow:0 24px 64px #0a25402e;max-height:88vh;overflow-y:auto;width:560px}.modal,.modal-header{background:#fff;background:var(--white)}.modal-header{align-items:flex-start;border-bottom:1px solid #e8eef5;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:18px 22px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.modal-body{padding:22px}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#64748b;color:var(--text3);cursor:pointer;display:flex;font-size:20px;justify-content:center;line-height:1;padding:3px;transition:all .12s}.modal-close:hover{background:#f6f9fc;background:var(--bg);color:#0a2540;color:var(--text)}.modal-meta{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:16px}.meta-item{background:#f6f9fc;background:var(--bg);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);padding:10px 12px}.meta-label{color:#64748b;color:var(--text3);font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.meta-value{color:#0a2540;color:var(--text);font-size:13px;font-weight:500}.section-label{color:#64748b;color:var(--text3);font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.desc-box{border:1px solid #e8eef5;border:1px solid var(--border);color:#475569;color:var(--text2);font-size:13px;line-height:1.7;margin-bottom:16px;padding:12px}.comment,.desc-box{background:#f6f9fc;background:var(--bg);border-radius:10px;border-radius:var(--radius-sm)}.comment{border-left:3px solid #e8eef5;border-left:3px solid var(--border);margin-bottom:8px;padding:11px 14px}.comment.admin-comment{background:#eff6ff;background:var(--blue-light);border-left-color:#2563eb;border-left-color:var(--blue)}.comment-author{align-items:center;color:#0a2540;color:var(--text);display:flex;font-size:12px;font-weight:600;gap:6px;margin-bottom:3px}.admin-tag{background:#2563eb;background:var(--blue);border-radius:5px;color:#fff;font-size:10px;font-weight:500;padding:1px 7px}.comment-text{color:#475569;color:var(--text2);font-size:13px;line-height:1.6}.comment-time{color:#64748b;color:var(--text3);font-size:11px;margin-top:4px}.toast-wrap{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{align-items:center;animation:slideUp .3s ease;background:#0a2540;background:var(--text);border:1px solid #ffffff14;border-radius:10px;border-radius:var(--radius-sm);box-shadow:0 20px 60px #0a25401f;box-shadow:var(--shadow-md);color:#fff;display:flex;font-size:13px;font-weight:500;gap:10px;min-width:260px;padding:12px 20px}.toast.success{background:#166534}.toast.error{background:#dc2626;background:var(--red)}.empty-state{color:#64748b;color:var(--text3);padding:56px 32px;text-align:center}.empty-icon{font-size:40px;margin-bottom:14px;opacity:.85}.empty-state p{font-size:14px;line-height:1.5}.pagination{align-items:center;border-top:1px solid #e8eef5;border-top:1px solid var(--border);display:flex;gap:6px;justify-content:center;padding:14px 0}.page-info{color:#64748b;color:var(--text3);font-size:12px;padding:0 12px}.login-page{background:#f6f9fc;background:var(--bg);display:flex;min-height:100vh}.login-left{align-items:center;background:linear-gradient(160deg,#0570de,#0353a4);display:flex;flex-direction:column;flex-shrink:0;justify-content:center;overflow:hidden;padding:48px;position:relative;width:440px}.login-left:before{background:#ffffff0f;height:260px;right:-60px;top:-60px;width:260px}.login-left:after,.login-left:before{border-radius:50%;content:"";position:absolute}.login-left:after{background:#ffffff0a;bottom:-40px;height:200px;left:-40px;width:200px}.login-left-logo{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:15px;display:flex;font-size:28px;font-weight:700;height:60px;justify-content:center;margin-bottom:26px;width:60px}.login-left h1,.login-left-logo{color:#fff;position:relative;z-index:1}.login-left h1{font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:10px;text-align:center}.login-left p{color:#ffffffbf;font-size:14px;line-height:1.7;position:relative;text-align:center;z-index:1}.login-features{margin-top:36px;position:relative;width:100%;z-index:1}.login-feature{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;gap:13px;padding:11px 0}.login-feature:last-child{border-bottom:none}.login-feature-icon{align-items:center;background:#ffffff1f;border-radius:9px;display:flex;flex-shrink:0;height:34px;justify-content:center;width:34px}.login-feature-icon i{color:#fff;font-size:17px}.login-feature-text{color:#ffffffd9;font-size:13px;font-weight:400}.login-right{align-items:center;display:flex;flex:1 1;justify-content:center;padding:48px}.login-card{max-width:400px;width:100%}.login-card h2{color:#0a2540;color:var(--text);font-size:22px;font-weight:600;letter-spacing:-.4px;margin-bottom:5px}.login-card p{color:#64748b;color:var(--text3);font-size:13px;margin-bottom:28px}.role-tabs{background:#f6f9fc;background:var(--bg);border-radius:10px;border-radius:var(--radius-sm);display:flex;gap:3px;margin-bottom:24px;padding:3px}.role-tab{align-items:center;background:none;border:none;border-radius:6px;color:#475569;color:var(--text2);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:12px;font-weight:400;gap:3px;padding:8px 4px;transition:all .15s}.role-tab.active{background:#fff;background:var(--white);box-shadow:0 1px 3px #0a25400d;box-shadow:var(--shadow-sm);color:#2563eb;color:var(--blue);font-weight:500}.login-btn{background:#2563eb;background:var(--blue);border:none;border-radius:10px;border-radius:var(--radius-sm);box-shadow:0 1px 3px #0570de40;color:#fff;cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:14px;font-weight:500;margin-top:4px;padding:10px;transition:all .15s;width:100%}.login-btn:hover{background:#1e40af;background:var(--blue-dark);box-shadow:0 3px 10px #0570de59;transform:translateY(-1px)}.demo-info{background:#eff6ff;background:var(--blue-light);border:1px solid #0570de26;border-radius:10px;border-radius:var(--radius-sm);color:#2563eb;color:var(--blue);font-size:12px;margin-top:14px;padding:10px 14px}.login-screen{align-items:center;background:#f6f9fc;background:var(--bg);display:flex;justify-content:center;min-height:100vh;padding:48px;position:relative}.login-glow{display:none}.login-logo{gap:10px;margin-bottom:24px}.login-logo,.logo-icon{align-items:center;display:flex}.logo-icon{background:linear-gradient(135deg,#0570de,#1a73e8);border-radius:12px;color:#fff;font-size:18px;font-weight:700;height:40px;justify-content:center;width:40px}.logo-text{color:#0a2540;color:var(--text);font-size:16px;font-weight:600}.logo-sub{color:#64748b;color:var(--text3);font-size:10px;letter-spacing:.5px;text-transform:uppercase}.login-title{color:#0a2540;color:var(--text);font-size:24px;font-weight:600;margin-bottom:6px}.login-sub{color:#64748b;color:var(--text3);font-size:14px;margin-bottom:28px}.form-card{background:#fff;background:var(--white);border:1px solid #e8eef5;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius);box-shadow:0 8px 24px #0a254014;box-shadow:var(--shadow);max-width:640px;padding:28px 30px}.form-tip{align-items:flex-start;background:#fffbeb;background:var(--amber-bg);border-left:3px solid #d97706;border-left:3px solid var(--amber);border-radius:10px;border-radius:var(--radius-sm);color:#d97706;color:var(--amber);display:flex;font-size:12px;gap:9px;margin-bottom:18px;padding:11px 14px}.success-wrap{flex-direction:column;margin:0 auto;max-width:440px;padding:60px 40px;text-align:center}.success-icon,.success-wrap{align-items:center;display:flex}.success-icon{animation:pulse 2s infinite;background:#f0fdf4;background:var(--green-bg);border-radius:50%;font-size:26px;height:62px;justify-content:center;margin-bottom:18px;width:62px}.ticket-id-chip{background:#eff6ff;background:var(--blue-light);border:1px solid #0570de26;border-radius:10px;border-radius:var(--radius-sm);color:#2563eb;color:var(--blue);display:inline-block;font-family:JetBrains Mono,monospace;font-family:var(--mono);font-size:13px;margin:12px 0 18px;padding:5px 14px}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.page{padding:22px 20px}}@media (max-width:900px){.sidebar{transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);width:270px}.sidebar.open{transform:translateX(0)}.sidebar-close-btn{display:flex}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.show{opacity:1;pointer-events:auto}.main-content{margin-left:0}.topbar-menu-btn{display:flex}}@media (max-width:768px){.topbar-greeting{display:none}.page{padding:16px 14px}.page-header{align-items:stretch;flex-direction:column;gap:12px}.page-header .btn,.page-header>button{justify-content:center;width:100%}table{min-width:640px}.card{overflow-x:auto}.modal{max-width:100%;width:calc(100vw - 28px)!important}.form-row{grid-template-columns:1fr}.login-brand-panel{display:none!important}.login-form-panel{padding:28px 18px!important}}@media (max-width:600px){.stats-grid{grid-template-columns:1fr}.topbar{gap:10px;padding:0 14px}.profile-stats-grid{grid-template-columns:1fr 1fr}.kanban-col{min-width:84vw;width:84vw}}.profile-chart{grid-gap:10px;align-items:end;display:grid;gap:10px;grid-template-columns:repeat(6,1fr);height:160px}.profile-chart-col{align-items:center;display:flex;flex-direction:column;gap:6px;min-width:0}.profile-chart-value{font-size:12px;font-weight:600;line-height:1}.profile-chart-bar-wrap{align-items:flex-end;display:flex;height:100px;justify-content:center;max-width:48px;width:100%}.profile-chart-bar{background:linear-gradient(180deg,#60a5fa,#2563eb);background:linear-gradient(180deg,#60a5fa,var(--blue));border-radius:6px 6px 2px 2px;transition:height .5s ease,filter .15s ease;width:100%}.profile-chart-col:hover .profile-chart-bar{filter:brightness(1.08) saturate(1.1)}.profile-chart-label{color:#64748b;color:var(--text3);font-size:10px;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}@media (max-width:700px){.profile-chart{grid-template-columns:repeat(3,1fr);height:auto;row-gap:20px}}.kanban{display:flex;gap:14px;min-height:480px;overflow-x:auto;padding:2px 2px 16px}.kanban-col{flex-shrink:0;min-width:288px;width:288px}.kanban-col-inner{background:#fff;border:1px solid #e8eef5;border:1px solid var(--border);border-radius:14px;box-shadow:0 1px 3px #0a25400d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%;max-height:calc(100vh - 215px);overflow:hidden;transition:box-shadow .2s ease}.kanban-col-inner:hover{box-shadow:0 8px 24px #0a254014;box-shadow:var(--shadow)}.kanban-col-bar{flex-shrink:0;height:4px}.kanban-col-head{align-items:center;border-bottom:1px solid #eef2f7;display:flex;flex-shrink:0;gap:8px;padding:13px 15px}.kanban-col-head>i{font-size:16px}.kanban-col-title{color:#0a2540;color:var(--text);font-size:13px;font-weight:700}.kanban-col-count{border-radius:10px;font-size:11px;font-weight:700;margin-left:auto;min-width:24px;padding:2px 9px;text-align:center}.kanban-col-body{flex:1 1;overflow-y:auto;padding:11px}.kanban-empty{color:#cbd5e1;font-size:12px;padding:32px 16px;text-align:center}.kanban-empty i{display:block;font-size:26px;margin-bottom:6px;opacity:.45}.kanban-card{animation:fadeInUp .22s ease backwards;background:#fff;border:1px solid #e8eef5;border:1px solid var(--border);border-radius:11px;margin-bottom:10px;padding:13px 14px 13px 17px;position:relative;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.kanban-card:before{background:#cbd5e1;background:var(--accent,#cbd5e1);border-radius:0 3px 3px 0;bottom:11px;content:"";left:0;position:absolute;top:11px;width:3px}.kanban-card:hover{border-color:#dbe6f3;box-shadow:0 10px 22px #0a25401a;transform:translateY(-2px)}.kanban-card.is-done{opacity:.7}.kanban-card-title{color:#0a2540;color:var(--text);font-size:13px;font-weight:600;line-height:1.45;margin-bottom:9px}.kanban-card.is-done .kanban-card-title{color:#64748b;color:var(--text3);text-decoration:line-through}.kanban-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.kanban-tag{border-radius:6px;font-size:10px;font-weight:600;padding:2px 9px}.kanban-foot{gap:8px;justify-content:space-between}.kanban-date,.kanban-foot{align-items:center;display:flex}.kanban-date{color:#64748b;color:var(--text3);font-size:11px;gap:4px}.kanban-date i{font-size:13px}.kanban-date.is-late{color:#dc2626;color:var(--red);font-weight:600}.kanban-check{align-items:center;background:#fff;border:1.5px solid #d1d9e6;border-radius:7px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;height:26px;justify-content:center;transition:all .14s ease;width:26px}.kanban-check i{font-size:14px}.kanban-check:hover{background:#16a34a;background:var(--green);border-color:#16a34a;border-color:var(--green);color:#fff;transform:scale(1.05)}.kanban-check.done{background:#10b981;border-color:#10b981;color:#fff;cursor:default}.ann-wrap{max-width:840px}.ann-toolbar{align-items:center;gap:12px;margin-bottom:20px}.ann-filters,.ann-toolbar{display:flex;flex-wrap:wrap}.ann-filters{gap:8px}.ann-chip{align-items:center;background:#fff;border:1px solid #e8eef5;border:1px solid var(--border);border-radius:999px;color:#475569;color:var(--text2);cursor:pointer;display:inline-flex;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:12.5px;font-weight:600;gap:6px;padding:7px 13px;transition:all .15s ease}.ann-chip:hover{border-color:#cbd9ea;color:#0a2540;color:var(--text)}.ann-chip.active{background:#2563eb;background:var(--chip,var(--blue));border-color:#0000;box-shadow:0 4px 12px #2563eb40;color:#fff}.ann-chip-count{align-items:center;background:#0000000f;border-radius:9px;color:inherit;display:inline-flex;font-size:11px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 6px}.ann-chip.active .ann-chip-count{background:#ffffff40}.ann-search{margin-left:auto;min-width:220px;position:relative}.ann-search i{color:#64748b;color:var(--text3);font-size:16px;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.ann-search input{background:#fff;border:1px solid #e8eef5;border:1px solid var(--border);border-radius:10px;color:#0a2540;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-family:var(--font);font-size:13px;padding:9px 12px 9px 36px;transition:all .15s ease;width:100%}.ann-search input:focus{border-color:#2563eb;border-color:var(--blue);box-shadow:0 0 0 3px #2563eb1f;outline:none}.ann-section-label{align-items:center;color:#64748b;color:var(--text3);display:flex;font-size:11px;font-weight:700;gap:7px;letter-spacing:.6px;margin:4px 2px 12px;text-transform:uppercase}.ann-card{animation:fadeInUp .28s ease backwards;background:#fff;border:1px solid #e8eef5;border-left:3px solid #cbd5e1;border:1px solid var(--border);border-left:3px solid var(--accent,#cbd5e1);border-radius:14px;box-shadow:0 1px 3px #0a25400d;box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden;padding:0;position:relative;transition:transform .16s ease,box-shadow .16s ease}.ann-card:hover{box-shadow:0 12px 28px #0a25401a;transform:translateY(-2px)}.ann-card.pinned{background:linear-gradient(180deg,#fffdf5,#fff 60%)}.ann-pin-banner{align-items:center;background:#fff8e6;border-bottom:1px solid #fcecc4;color:#d97706;display:flex;font-size:11px;font-weight:700;gap:6px;letter-spacing:.3px;padding:6px 20px}.ann-body{padding:18px 20px}.ann-head{align-items:flex-start;display:flex;gap:13px}.ann-icon{align-items:center;background:#eff6ff;background:var(--accent-bg,#eff6ff);border-radius:12px;display:flex;flex-shrink:0;height:42px;justify-content:center;width:42px}.ann-icon i{color:#2563eb;color:var(--accent,var(--blue));font-size:21px}.ann-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}.ann-title{color:#0a2540;color:var(--text);font-size:15.5px;font-weight:700}.ann-badge{border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.2px;padding:2px 9px}.ann-badge.dept{background:#f1f5f9;color:#64748b}.ann-meta{align-items:center;color:#64748b;color:var(--text3);display:flex;font-size:12px;gap:6px}.ann-actions{display:flex;gap:5px;margin-left:auto;opacity:0;transition:opacity .15s ease}.ann-card:hover .ann-actions{opacity:1}.ann-act-btn{align-items:center;background:#fff;border:1px solid #e8eef5;border:1px solid var(--border);border-radius:8px;color:#64748b;color:var(--text3);cursor:pointer;display:flex;height:31px;justify-content:center;transition:all .13s ease;width:31px}.ann-act-btn i{font-size:15px}.ann-act-btn:hover{border-color:#cbd9ea;color:#0a2540;color:var(--text)}.ann-act-btn.active{background:#fff8e6;border-color:#fcecc4;color:#d97706}.ann-act-btn.danger:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.ann-msg{color:#475569;font-size:14px;line-height:1.7;margin-top:12px;padding-left:55px;white-space:pre-wrap}.ann-foot{color:#64748b;color:var(--text3);font-size:11.5px;gap:14px;margin-top:14px;padding-left:55px}.ann-foot,.ann-foot-item{align-items:center;display:flex}.ann-foot-item{gap:5px}.ann-foot-item i{font-size:14px}@media (max-width:600px){.ann-search{margin-left:0;width:100%}.ann-foot,.ann-msg{padding-left:0}.ann-actions{opacity:1}}
/*# sourceMappingURL=main.60df4518.css.map*/