@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-navy: #1A2B6D;--brand-blue: #2B4EE6;--brand-blue-lt: #EEF2FF;--brand-blue-md: #C7D2FE;--success: #16A34A;--success-bg: #DCFCE7;--warning: #D97706;--warning-bg: #FEF3C7;--danger: #DC2626;--danger-bg: #FEE2E2;--info: #0284C7;--info-bg: #E0F2FE;--gray-50: #F8FAFC;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-300: #CBD5E1;--gray-400: #94A3B8;--gray-500: #64748B;--gray-600: #475569;--gray-700: #334155;--gray-800: #1E293B;--gray-900: #0F172A;--sidebar-w: 240px;--topbar-h: 64px;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.05);--shadow: 0 4px 6px -1px rgba(0,0,0,.08),0 2px 4px -2px rgba(0,0,0,.06);--shadow-md: 0 10px 15px -3px rgba(0,0,0,.08),0 4px 6px -4px rgba(0,0,0,.05);--shadow-lg: 0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.05);--font: "DM Sans", system-ui, sans-serif;--font-mono: "DM Mono", monospace}html{font-size:15px}body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer}input,textarea,select{font-family:var(--font)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:99px}.layout{display:flex;min-height:100vh}.layout__sidebar{width:var(--sidebar-w);flex-shrink:0;position:fixed;top:0;left:0;bottom:0;z-index:100}.layout__body{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}.layout__topbar{height:var(--topbar-h);position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--gray-200);display:flex;align-items:center;padding:0 28px;gap:16px}.layout__content{flex:1;padding:28px;overflow-x:hidden}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.card--compact{padding:16px 20px}.stat-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:flex-start;gap:16px}.stat-card__icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card__label{font-size:.82rem;color:var(--gray-500);font-weight:500}.stat-card__value{font-size:1.75rem;font-weight:700;color:var(--gray-900);line-height:1.1;margin-top:2px}.stat-card__sub{font-size:.78rem;color:var(--gray-400);margin-top:3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);font-size:.88rem;font-weight:600;border:none;cursor:pointer;transition:background .15s,box-shadow .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.98)}.btn--primary{background:var(--brand-blue);color:#fff}.btn--primary:hover{background:#24c;box-shadow:0 4px 12px #2b4ee64d}.btn--secondary{background:var(--gray-100);color:var(--gray-700)}.btn--secondary:hover{background:var(--gray-200)}.btn--danger{background:var(--danger-bg);color:var(--danger)}.btn--danger:hover{background:#fca5a5}.btn--success{background:var(--success-bg);color:var(--success)}.btn--success:hover{background:#bbf7d0}.btn--ghost{background:transparent;color:var(--gray-600)}.btn--ghost:hover{background:var(--gray-100)}.btn--outline{background:transparent;color:var(--brand-blue);border:1.5px solid var(--brand-blue)}.btn--outline:hover{background:var(--brand-blue-lt)}.btn--sm{padding:5px 12px;font-size:.82rem}.btn--lg{padding:11px 24px;font-size:.95rem}.btn--full{width:100%;justify-content:center}.btn--icon{padding:8px;border-radius:var(--radius)}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.75rem;font-weight:600}.badge--success{background:var(--success-bg);color:var(--success)}.badge--warning{background:var(--warning-bg);color:var(--warning)}.badge--danger{background:var(--danger-bg);color:var(--danger)}.badge--info{background:var(--info-bg);color:var(--info)}.badge--neutral{background:var(--gray-100);color:var(--gray-600)}.badge--blue{background:var(--brand-blue-lt);color:var(--brand-blue)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.83rem;font-weight:600;color:var(--gray-700)}.form-label span{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:9px 13px;border:1.5px solid var(--gray-200);border-radius:var(--radius);font-size:.9rem;color:var(--gray-800);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand-blue);box-shadow:0 0 0 3px #2b4ee61f}.form-input::placeholder{color:var(--gray-400)}.form-error{font-size:.78rem;color:var(--danger)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}table{width:100%;border-collapse:collapse;background:#fff}thead tr{background:var(--gray-50);border-bottom:1px solid var(--gray-200)}th{padding:11px 16px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);text-align:left;white-space:nowrap}td{padding:13px 16px;font-size:.88rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--gray-50)}.progress-bar{height:7px;border-radius:99px;background:var(--gray-200);overflow:hidden}.progress-bar__fill{height:100%;border-radius:99px;background:var(--brand-blue);transition:width .4s ease}.workflow-track{display:flex;align-items:center;gap:0}.workflow-step{display:flex;flex-direction:column;align-items:center;flex:1;text-align:center}.workflow-step__circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border:2px solid var(--gray-300);background:#fff;color:var(--gray-400);position:relative;z-index:1}.workflow-step__circle--done{background:var(--success);border-color:var(--success);color:#fff}.workflow-step__circle--active{background:var(--warning-bg);border-color:var(--warning);color:var(--warning)}.workflow-step__circle--pending{background:#fff;border-color:var(--gray-300);color:var(--gray-400)}.workflow-step__label{font-size:.75rem;color:var(--gray-500);margin-top:6px;font-weight:500}.workflow-step__sub{font-size:.7rem;color:var(--gray-400);margin-top:2px}.workflow-connector{flex:1;height:2px;background:var(--gray-200);margin-bottom:30px}.workflow-connector--done{background:var(--success)}.sidebar{background:var(--brand-navy);height:100%;display:flex;flex-direction:column;overflow-y:auto}.sidebar__logo{padding:20px 20px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar__logo-icon{width:36px;height:36px;border-radius:10px;background:var(--brand-blue);display:flex;align-items:center;justify-content:center;color:#fff}.sidebar__logo-name{font-size:.95rem;font-weight:700;color:#fff;line-height:1.1}.sidebar__logo-sub{font-size:.7rem;color:#ffffff80}.sidebar__nav{padding:14px 12px;flex:1;display:flex;flex-direction:column;gap:2px}.sidebar__link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);font-size:.875rem;font-weight:500;color:#ffffffa6;transition:background .15s,color .15s}.sidebar__link:hover{background:#ffffff12;color:#ffffffe6}.sidebar__link--active{background:var(--brand-blue);color:#fff}.sidebar__link-badge{margin-left:auto;background:var(--danger);color:#fff;width:20px;height:20px;border-radius:99px;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}.sidebar__footer{padding:12px 16px 16px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}.sidebar__user-name{font-size:.82rem;font-weight:600;color:#fff}.sidebar__user-id{font-size:.72rem;color:#ffffff73}.topbar__title{flex:1}.topbar__title h1{font-size:1.1rem;font-weight:700;color:var(--gray-900)}.topbar__title p{font-size:.78rem;color:var(--gray-400)}.topbar__actions{display:flex;align-items:center;gap:10px;margin-left:auto}.notif-btn{position:relative;width:38px;height:38px;border-radius:50%;background:var(--gray-100);border:none;display:flex;align-items:center;justify-content:center;color:var(--gray-600);cursor:pointer}.notif-btn__dot{position:absolute;top:5px;right:5px;width:16px;height:16px;border-radius:99px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.page-header{margin-bottom:24px}.page-header h1{font-size:1.4rem;font-weight:700;color:var(--gray-900)}.page-header p{font-size:.85rem;color:var(--gray-500);margin-top:3px}.page-header__row{display:flex;align-items:center;justify-content:space-between}.section-title{font-size:1rem;font-weight:700;color:var(--gray-800);margin-bottom:16px}.avatar{border-radius:50%;object-fit:cover;background:var(--brand-blue-lt);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--brand-blue);flex-shrink:0}.avatar--sm{width:32px;height:32px;font-size:.78rem}.avatar--md{width:40px;height:40px;font-size:.9rem}.avatar--lg{width:56px;height:56px;font-size:1.1rem}.avatar--xl{width:88px;height:88px;font-size:1.6rem}.tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:20px}.tab{padding:10px 18px;font-size:.88rem;font-weight:500;color:var(--gray-500);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s}.tab:hover{color:var(--gray-700)}.tab--active{color:var(--brand-blue);border-bottom-color:var(--brand-blue);font-weight:600}.modal-overlay{position:fixed;inset:0;background:#00000059;backdrop-filter:blur(2px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}.modal{background:#fff;border-radius:var(--radius-xl);padding:28px;max-width:520px;width:100%;box-shadow:var(--shadow-lg);animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal__title{font-size:1.1rem;font-weight:700;color:var(--gray-900)}.modal__footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-warning{color:var(--warning)}.text-muted{color:var(--gray-400)}.text-sm{font-size:.82rem}.text-xs{font-size:.74rem}.text-bold{font-weight:700}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.w-full{width:100%}.empty-state{text-align:center;padding:48px 24px;color:var(--gray-400)}.empty-state p{font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border-radius:50%;border:2.5px solid var(--gray-200);border-top-color:var(--brand-blue);animation:spin .7s linear infinite;display:inline-block}.spinner--lg{width:32px;height:32px;border-width:3px}.page-loading{display:flex;align-items:center;justify-content:center;height:calc(100vh - var(--topbar-h));gap:12px;color:var(--gray-400);font-size:.9rem}.auth-page{min-height:100vh;display:flex;align-items:stretch}.auth-page__brand{width:400px;flex-shrink:0;background:var(--brand-navy);padding:48px 40px;display:flex;flex-direction:column;justify-content:space-between}.auth-page__form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.auth-card{width:100%;max-width:440px}.auth-card__logo{display:flex;align-items:center;gap:10px;margin-bottom:32px}.auth-card__logo-icon{width:40px;height:40px;border-radius:11px;background:var(--brand-navy);display:flex;align-items:center;justify-content:center;color:#fff}.auth-card__title{font-size:1.55rem;font-weight:700;color:var(--gray-900)}.auth-card__sub{font-size:.88rem;color:var(--gray-500);margin-top:6px;margin-bottom:28px}.sla-pill{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;padding:3px 9px;border-radius:99px}.sla-pill--ok{background:var(--success-bg);color:var(--success)}.sla-pill--risk{background:var(--warning-bg);color:var(--warning)}.sla-pill--overdue{background:var(--danger-bg);color:var(--danger)}.upload-zone{border:2px dashed var(--brand-blue);border-radius:var(--radius-lg);padding:40px 24px;text-align:center;cursor:pointer;transition:background .15s;background:var(--brand-blue-lt)}.upload-zone:hover{background:#e0e7ff}.upload-zone p{font-size:.88rem;color:var(--gray-500);margin-top:8px}.upload-zone strong{color:var(--brand-blue);font-weight:600}.notif-item{display:flex;gap:14px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--gray-100)}.notif-item:last-child{border-bottom:none}.notif-item--unread{background:#fafbff;margin:0 -20px;padding:16px 20px}.notif-item__icon{width:38px;height:38px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}.notif-item__title{font-size:.88rem;font-weight:600;color:var(--gray-800)}.notif-item__msg{font-size:.82rem;color:var(--gray-500);margin-top:2px}.notif-item__time{font-size:.75rem;color:var(--gray-400);white-space:nowrap}.notif-item__unread-dot{width:8px;height:8px;border-radius:50%;background:var(--brand-blue);flex-shrink:0;margin-top:6px}.doc-row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--gray-100)}.doc-row:last-child{border-bottom:none}.doc-row__icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.doc-row__name{font-size:.88rem;font-weight:600;color:var(--gray-800)}.doc-row__file{font-size:.76rem;color:var(--gray-400)}.doc-row__actions{margin-left:auto;display:flex;gap:6px}.pagination{display:flex;align-items:center;gap:4px;justify-content:flex-end;margin-top:16px}.page-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--gray-200);background:#fff;font-size:.82rem;font-weight:500;color:var(--gray-600);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .12s}.page-btn:hover{background:var(--gray-100)}.page-btn--active{background:var(--brand-blue);color:#fff;border-color:var(--brand-blue)}.alert{display:flex;align-items:flex-start;gap:10px;padding:13px 16px;border-radius:var(--radius);font-size:.85rem}.alert--warning{background:var(--warning-bg);color:#92400e;border:1px solid #FCD34D}.alert--danger{background:var(--danger-bg);color:#991b1b;border:1px solid #FCA5A5}.alert--success{background:var(--success-bg);color:#166534;border:1px solid #86EFAC}.alert--info{background:var(--info-bg);color:#075985;border:1px solid #7DD3FC}
