@import "https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700&display=swap";:root{--teal:#3595a9;--teal-dark:#2a7a8d;--teal-light:#e8f4f7;--navy:#001d4b;--amber:#e7b46f;--amber-light:#fdf3e3;--white:#fff;--bg:#f4f7fa;--border:#e2e8f0;--border-dk:#cbd5e1;--text:#0f172a;--text-2:#475569;--text-3:#94a3b8;--ok-bg:#dcfce7;--ok-tx:#15803d;--ko-bg:#fee2e2;--ko-tx:#b91c1c;--wa-bg:#fef3c7;--wa-tx:#92400e;--in-bg:#eef2ff;--in-tx:#4338ca;--font:"Nunito", sans-serif;--s05:4px;--s1:8px;--s2:16px;--s3:24px;--s4:32px;--s5:40px;--sh-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--sh-md:0 4px 16px #0000001a;--r-sm:6px;--r:8px;--r-lg:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-size:14px}button{cursor:pointer;font-family:var(--font);background:0 0;border:none}svg{flex-shrink:0;display:block}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}.btn{align-items:center;gap:var(--s1);padding:8px var(--s2);border-radius:var(--r-sm);font-family:var(--font);cursor:pointer;white-space:nowrap;border:1.5px solid #0000;font-size:14px;font-weight:600;transition:background .12s,border-color .12s;display:inline-flex}.btn-primary{background:var(--teal);color:#fff;border-color:var(--teal)}.btn-primary:hover{background:var(--teal-dark);border-color:var(--teal-dark)}.btn-secondary{color:var(--text);border-color:var(--border);background:#fff}.btn-secondary:hover{background:var(--bg);border-color:var(--border-dk)}.btn-ghost{color:var(--text-2);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-sm{padding:5px 12px;font-size:13px}.badge{white-space:nowrap;border-radius:10px;align-items:center;padding:2px 10px;font-size:12px;font-weight:700;display:inline-flex}.b-teal{background:var(--teal-light);color:var(--teal-dark)}.b-amber{background:var(--amber-light);color:#7a5419}.b-ok{background:var(--ok-bg);color:var(--ok-tx)}.b-ko{background:var(--ko-bg);color:var(--ko-tx)}.b-warn{background:var(--wa-bg);color:var(--wa-tx)}.b-info{background:var(--in-bg);color:var(--in-tx)}.card{border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sh-sm);background:#fff}.card-p{padding:var(--s3)}.loading-screen{height:100vh;color:var(--text-2);justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.app{height:100vh;display:flex;overflow:hidden}.sidebar{z-index:90;border-right:1px solid var(--border);width:220px;min-width:220px;height:100vh;box-shadow:var(--sh-sm);background:#fff;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.sidebar-logo{height:72px;padding:0 var(--s2);flex-shrink:0;justify-content:center;align-items:center;display:flex}.logo-img{object-fit:contain;width:auto;height:40px}.sidebar-nav{padding:var(--s2) 0;flex:1;overflow:hidden auto}.nav-item{align-items:center;gap:var(--s2);padding:11px var(--s2);color:var(--text-2);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative;overflow:hidden}.nav-item:hover{color:var(--text)}.nav-item.active{background:var(--teal-light);color:var(--teal-dark)}.nav-item.active:before{content:"";background:var(--teal);border-radius:0 2px 2px 0;width:3px;position:absolute;top:5px;bottom:5px;left:0}.nav-icon{opacity:.55;flex-shrink:0;width:18px;height:18px;transition:opacity .12s}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-label{flex:1}.sidebar-footer{padding:0 0 var(--s3) 0;flex-shrink:0}.nav-settings{align-items:center;gap:var(--s2);padding:11px var(--s2);color:var(--text-2);cursor:pointer;white-space:nowrap;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative;overflow:hidden}.nav-settings:hover{background:var(--bg);color:var(--text)}.nav-settings.active{background:var(--teal-light);color:var(--teal-dark)}.nav-settings.active:before{content:"";background:var(--teal);border-radius:0 2px 2px 0;width:3px;position:absolute;top:5px;bottom:5px;left:0}.nav-settings svg{opacity:.55}.nav-settings:hover svg,.nav-settings.active svg{opacity:1}.header{background:var(--white);border-bottom:1px solid var(--border);height:64px;box-shadow:var(--sh-sm);padding:0 var(--s4);align-items:center;gap:var(--s2);z-index:10;flex-shrink:0;display:flex}.hdr-title{flex:1;font-size:16px;font-weight:700}.hdr-actions{align-items:center;gap:4px;display:flex}.hdr-btn{border-radius:var(--r-sm);width:34px;height:34px;color:var(--text-2);justify-content:center;align-items:center;transition:background .12s;display:flex;position:relative}.hdr-btn:hover{background:var(--bg)}.hdr-user{align-items:center;gap:var(--s1);padding:5px var(--s1) 5px var(--s2);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;margin-left:var(--s1);transition:background .12s,border-color .12s;display:flex}.hdr-user:hover{background:var(--bg);border-color:var(--border-dk)}.hdr-av{background:var(--teal);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:flex}.hdr-uname{font-size:13px;font-weight:600}.notif-badge{background:var(--ko-tx);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.notif-panel{border:1px solid var(--border);border-radius:var(--r);width:380px;box-shadow:var(--sh-md);z-index:100;background:#fff;flex-direction:column;max-height:480px;margin-top:8px;display:flex;position:absolute;top:100%;right:0}.notif-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-tabs{border-bottom:1px solid var(--border);display:flex}.notif-tab{text-align:center;cursor:pointer;color:var(--text-3);font-size:12px;font-weight:600;font-family:var(--font);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:8px;transition:color .12s,border-color .12s}.notif-tab:hover{color:var(--text)}.notif-tab.active{color:var(--teal);border-bottom-color:var(--teal)}.notif-list{flex:1;max-height:360px;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:8px;padding:12px 16px;transition:background .1s;display:flex}.notif-item:hover{background:var(--bg)}.notif-item.unread{background:var(--teal-light)}.notif-item.unread:hover{background:#cde8ee}.notif-item-body{flex:1;min-width:0}.notif-item-title{color:var(--text);margin-bottom:2px;font-size:13px;font-weight:600}.notif-item-text{color:var(--text-2);margin-bottom:4px;font-size:12px;line-height:1.5}.notif-item-date{color:var(--text-3);font-size:11px}.notif-item-actions{flex-shrink:0;gap:4px;padding-top:2px;display:flex}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.content{padding:var(--s4);flex:1;overflow:hidden auto}.login-page{background:var(--bg);justify-content:center;align-items:center;height:100vh;display:flex}.login-card{border-radius:var(--r-lg);border:1px solid var(--border);width:400px;box-shadow:var(--sh-md);padding:var(--s5);background:#fff}.login-logo{align-items:center;gap:var(--s1);margin-bottom:var(--s4);display:flex}.login-title{color:var(--navy);margin-bottom:var(--s05);font-size:22px;font-weight:700}.login-sub{color:var(--text-2);margin-bottom:var(--s2);font-size:14px}.login-hint{color:var(--text-3);margin-bottom:var(--s3);font-size:12px}.login-hint a{color:var(--teal);font-weight:600;text-decoration:none}.login-hint a:hover{text-decoration:underline}.login-form{gap:var(--s2);flex-direction:column;display:flex}.login-label{gap:var(--s05);color:var(--text-2);flex-direction:column;font-size:13px;font-weight:600;display:flex}.login-label input{border:1px solid var(--border);border-radius:var(--r-sm);font-family:var(--font);color:var(--text);padding:10px 12px;font-size:14px;transition:border-color .12s}.login-label input:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px #3595a926}.login-btn{width:100%;margin-top:var(--s1);justify-content:center;padding:11px}.login-error{background:var(--ko-bg);color:var(--ko-tx);padding:var(--s1) var(--s2);border-radius:var(--r-sm);font-size:13px;font-weight:600}
