@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--ink: #16150f;--ink2: #5c5a52;--ink3: #9c9a90;--paper: #faf9f6;--card: #ffffff;--lift: #f2f1ec;--groove: #e8e6df;--groove2: #d4d2c8;--pine: #0f5132;--pine-l: #e8f5ee;--pine-b: #1a7a4a;--fire: #991b1b;--fire-l: #fef2f2;--fire-b: #dc2626;--gold: #78350f;--gold-l: #fffbeb;--gold-b: #d97706;--ocean: #1e3a8a;--ocean-l: #eff6ff;--ocean-b: #3b82f6;--r: 6px;--r2: 10px;--r3: 14px;--mono: "JetBrains Mono", monospace;--sans: "DM Sans", sans-serif;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow2: 0 4px 16px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.06)}html,body,#root{height:100%;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--groove2);border-radius:3px}.app-shell{display:grid;grid-template-columns:220px 1fr;height:100vh;overflow:hidden}.main-area{display:flex;flex-direction:column;overflow:hidden}.page-content{flex:1;overflow-y:auto;padding:22px}.sidebar{background:var(--card);border-right:1px solid var(--groove);display:flex;flex-direction:column;box-shadow:var(--shadow)}.sb-top{padding:16px 14px 12px;border-bottom:1px solid var(--groove)}.sb-logo{display:flex;align-items:center;gap:9px}.sb-badge{width:32px;height:32px;border-radius:7px;background:var(--pine);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:600;font-size:12px;color:#fff;flex-shrink:0}.sb-title{font-weight:700;font-size:14px}.sb-sub{font-size:10px;color:var(--ink3);letter-spacing:.04em;margin-top:1px}.sb-nav{flex:1;padding:10px 8px;overflow-y:auto}.nav-section{margin-bottom:18px}.nav-section-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);padding:0 8px;margin-bottom:4px;display:block}.nav-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border-radius:var(--r);background:none;border:none;color:var(--ink2);font-family:var(--sans);font-size:12px;font-weight:500;cursor:pointer;text-align:left;transition:background .1s,color .1s;margin-bottom:2px}.nav-item:hover{background:var(--lift);color:var(--ink)}.nav-item.active{background:var(--pine-l);color:var(--pine);font-weight:600}.nav-item.locked{opacity:.38;cursor:not-allowed}.nav-item svg{flex-shrink:0;width:14px;height:14px}.lock-tag{margin-left:auto;font-size:9px;background:var(--fire-l);color:var(--fire);border:1px solid rgba(153,27,27,.18);border-radius:3px;padding:1px 5px;font-family:var(--mono);font-weight:600}.sb-footer{padding:10px 8px 14px;border-top:1px solid var(--groove)}.user-card{background:var(--lift);border:1px solid var(--groove);border-radius:var(--r2);padding:10px 12px;margin-bottom:6px}.user-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;flex-shrink:0;font-family:var(--mono)}.nric-indicator{margin:0 8px 10px;padding:9px 11px;background:var(--lift);border:1px solid var(--groove);border-radius:var(--r)}.nric-lbl{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);margin-bottom:5px}.nric-val{font-family:var(--mono);font-size:12px}.nric-full{color:#166534}.nric-partial{color:#78350f}.nric-hidden{color:#991b1b}.topbar{background:var(--card);border-bottom:1px solid var(--groove);padding:12px 22px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);flex-shrink:0}.topbar-title{font-size:15px;font-weight:700}.topbar-sub{font-size:10px;color:var(--ink3);font-family:var(--mono);margin-top:2px}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border-radius:var(--r);font-family:var(--sans);font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .12s;white-space:nowrap;line-height:1;text-decoration:none}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:var(--pine);color:#fff;border-color:var(--pine-b)}.btn-primary:hover:not(:disabled){background:var(--pine-b)}.btn-secondary{background:var(--card);color:var(--ink2);border-color:var(--groove2)}.btn-secondary:hover:not(:disabled){background:var(--lift);color:var(--ink)}.btn-ghost{background:transparent;color:var(--ink2)}.btn-ghost:hover:not(:disabled){background:var(--lift)}.btn-danger{background:var(--fire-l);color:var(--fire);border-color:#991b1b33}.btn-danger:hover:not(:disabled){background:var(--fire-b);color:#fff;border-color:var(--fire-b)}.btn-warn{background:var(--gold-l);color:var(--gold);border-color:#78350f2e}.btn-warn:hover:not(:disabled){background:var(--gold-b);color:#fff}.btn-sm{padding:5px 10px;font-size:11px}.btn-xs{padding:3px 7px;font-size:10px}.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-family:var(--mono);border:1px solid transparent}.badge-admin{background:#fef2f2;color:#991b1b;border-color:#991b1b33}.badge-manager{background:#fffbeb;color:#78350f;border-color:#78350f33}.badge-supervisor{background:#eff6ff;color:#1e3a8a;border-color:#1e3a8a33}.badge-officer{background:#faf5ff;color:#4c1d95;border-color:#4c1d9533}.badge-active{background:#f0fdf4;color:#166534;border-color:#16653433}.badge-inactive{background:#fef2f2;color:#991b1b;border-color:#991b1b33}.badge-suspended{background:#fffbeb;color:#92400e;border-color:#92400e33}.badge-draft{background:#f5f5f4;color:#57534e;border-color:#57534e33}.badge-submitted{background:#eff6ff;color:#1e3a8a;border-color:#1e3a8a33}.badge-under_review{background:#fffbeb;color:#78350f;border-color:#78350f33}.badge-approved{background:#f0fdf4;color:#166534;border-color:#16653433}.badge-escalated{background:#fef2f2;color:#991b1b;border-color:#991b1b33}.badge-closed{background:#f5f3ff;color:#4c1d95;border-color:#4c1d9533}.rbac-allow{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-family:var(--mono);font-weight:600;padding:2px 7px;border-radius:3px;background:#f0fdf4;color:#166534;border:1px solid rgba(22,101,52,.2)}.rbac-deny{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-family:var(--mono);font-weight:600;padding:2px 7px;border-radius:3px;background:#fef2f2;color:#991b1b;border:1px solid rgba(153,27,27,.2)}.rbac-partial{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-family:var(--mono);font-weight:600;padding:2px 7px;border-radius:3px;background:#fffbeb;color:#78350f;border:1px solid rgba(120,53,15,.2)}.rbac-own{display:inline-flex;align-items:center;gap:3px;font-size:10px;font-family:var(--mono);font-weight:600;padding:2px 7px;border-radius:3px;background:#eff6ff;color:#1e3a8a;border:1px solid rgba(30,58,138,.2)}.card{background:var(--card);border:1px solid var(--groove);border-radius:var(--r3);overflow:hidden;box-shadow:var(--shadow)}.card-header{padding:13px 17px;border-bottom:1px solid var(--groove);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--ink)}.card-body{padding:17px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:18px}.stat-card{background:var(--card);border:1px solid var(--groove);border-radius:var(--r2);padding:13px 15px;box-shadow:var(--shadow)}.stat-label{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:7px}.stat-value{font-size:26px;font-weight:700;font-family:var(--mono);line-height:1}.stat-sub{font-size:10px;color:var(--ink3);margin-top:4px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);padding:9px 13px;text-align:left;border-bottom:1px solid var(--groove);white-space:nowrap;background:var(--lift)}td{padding:10px 13px;border-bottom:1px solid var(--groove);font-size:12px;color:var(--ink2)}tr:last-child td{border-bottom:none}.table-row-clickable:hover td{background:var(--paper);cursor:pointer}label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);display:flex;align-items:center;gap:5px;margin-bottom:5px}input,textarea,select{width:100%;background:var(--card);color:var(--ink);border:1px solid var(--groove2);border-radius:var(--r);padding:8px 11px;font-family:var(--sans);font-size:12px;outline:none;transition:border-color .12s,box-shadow .12s}input:focus,textarea:focus,select:focus{border-color:var(--pine);box-shadow:0 0 0 3px #0f51321a}input::placeholder,textarea::placeholder{color:var(--ink3)}input:disabled,select:disabled,textarea:disabled{background:var(--lift);color:var(--ink3);cursor:not-allowed;border-color:var(--groove)}textarea{resize:vertical;min-height:70px;line-height:1.5}select option{background:var(--card)}input[type=date],input[type=time]{color-scheme:light}input[type=checkbox]{width:14px;height:14px;accent-color:var(--pine);cursor:pointer;flex-shrink:0}.form-group{margin-bottom:13px}.form-group:last-child{margin-bottom:0}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.alert{padding:10px 13px;border-radius:var(--r);font-size:12px;display:flex;align-items:flex-start;gap:8px;line-height:1.55;margin-bottom:13px;border:1px solid}.alert svg{flex-shrink:0;margin-top:1px}.alert-info{background:var(--ocean-l);color:var(--ocean);border-color:#1e3a8a26}.alert-warn{background:var(--gold-l);color:var(--gold);border-color:#78350f26}.alert-error{background:var(--fire-l);color:var(--fire);border-color:#991b1b26}.alert-success{background:var(--pine-l);color:var(--pine);border-color:#0f513226}.modal-overlay{min-height:500px;background:#00000073;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px;border-radius:var(--r3)}.modal-box{background:var(--card);border:1px solid var(--groove2);border-radius:var(--r3);width:100%;max-width:660px;overflow:hidden;box-shadow:var(--shadow2)}.modal-header{padding:15px 19px;border-bottom:1px solid var(--groove);display:flex;align-items:center;justify-content:space-between;background:var(--lift)}.modal-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}.modal-body{padding:19px;max-height:520px;overflow-y:auto}.modal-footer{padding:13px 19px;border-top:1px solid var(--groove);display:flex;align-items:center;justify-content:flex-end;gap:8px;background:var(--lift)}.step-bar{display:flex;gap:0;margin-bottom:22px;overflow-x:auto;padding-bottom:2px}.step-item{display:flex;align-items:center;flex-shrink:0}.step-pill{display:flex;align-items:center;gap:6px;padding:6px 11px;border-radius:var(--r);font-size:11px;font-weight:600;transition:all .15s;border:1px solid var(--groove)}.step-done{background:var(--pine-l);color:var(--pine);border-color:#0f513233}.step-active{background:var(--pine);color:#fff;border-color:var(--pine)}.step-todo{background:var(--lift);color:var(--ink3)}.step-line{width:14px;height:1px;background:var(--groove);margin:0 2px}.chip-grid{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.chip{padding:5px 10px;border:1px solid var(--groove2);border-radius:3px;font-size:11px;cursor:pointer;font-family:var(--mono);color:var(--ink3);transition:all .12s;background:var(--card)}.chip:hover{border-color:var(--pine);color:var(--ink2)}.chip.selected{background:var(--pine-l);border-color:#0f51324d;color:var(--pine)}.nric-field-display{display:flex;align-items:center;justify-content:space-between;padding:8px 11px;background:var(--lift);border:1px solid var(--groove);border-radius:var(--r);font-family:var(--mono);font-size:12px}.nric-chip{font-size:9px;padding:2px 6px;border-radius:3px;font-family:var(--mono);font-weight:600;border:1px solid}.nric-chip-full{background:#f0fdf4;color:#166534;border-color:#16653433}.nric-chip-partial{background:#fffbeb;color:#78350f;border-color:#78350f33}.nric-chip-hidden{background:#fef2f2;color:#991b1b;border-color:#991b1b33}.perm-matrix{border:1px solid var(--groove);border-radius:var(--r2);overflow:hidden}.perm-matrix-head{display:grid;grid-template-columns:185px repeat(4,1fr);background:var(--lift);border-bottom:1px solid var(--groove)}.perm-matrix-head-cell{padding:9px 11px;font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);text-align:center}.perm-matrix-head-cell:first-child{text-align:left}.perm-matrix-row{display:grid;grid-template-columns:185px repeat(4,1fr);border-bottom:1px solid var(--groove)}.perm-matrix-row:last-child{border-bottom:none}.perm-matrix-row:hover{background:var(--lift)}.perm-row-label{padding:9px 11px;font-size:11px;font-weight:500;color:var(--ink2);display:flex;align-items:center;gap:6px;border-right:1px solid var(--groove)}.perm-cell{padding:9px 11px;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--groove)}.perm-cell:last-child{border-right:none}.perm-cat-row{grid-column:1 / -1;background:var(--paper);padding:7px 11px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);border-bottom:1px solid var(--groove)}.tab-bar{display:flex;gap:0;border-bottom:1px solid var(--groove);margin-bottom:16px}.tab-btn{padding:8px 14px;background:none;border:none;border-bottom:2px solid transparent;font-family:var(--sans);font-size:12px;font-weight:500;color:var(--ink3);cursor:pointer;transition:all .12s}.tab-btn:hover{color:var(--ink2)}.tab-btn.active{color:var(--pine);border-bottom-color:var(--pine);font-weight:600}.section-sep{display:flex;align-items:center;gap:10px;margin:14px 0}.section-sep-label{font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);white-space:nowrap}.section-sep:before,.section-sep:after{content:"";flex:1;height:1px;background:var(--groove)}.field-label{font-size:9px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--ink3);margin-bottom:3px;display:flex;align-items:center;gap:5px}.field-value{font-size:13px;color:var(--ink)}.field-value.mono{font-family:var(--mono);font-size:12px}.field-value.muted{color:var(--ink3);font-style:italic}.field-value.restricted{color:var(--fire);font-family:var(--mono);font-size:11px}.field-value.pine{color:var(--pine);font-family:var(--mono)}.cb-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink2);cursor:pointer;padding:5px 0;border-bottom:1px solid var(--groove)}.compliance-bar{display:flex;align-items:center;gap:9px;font-size:11px;color:var(--ink3);padding:8px 13px;background:var(--card);border:1px solid var(--groove);border-radius:var(--r);margin-bottom:17px;box-shadow:var(--shadow)}.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--pine);flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:14px}.access-denied-icon{width:54px;height:54px;border-radius:50%;background:var(--fire-l);border:1px solid rgba(153,27,27,.2);display:flex;align-items:center;justify-content:center}.toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:7px;z-index:9999;max-width:300px}.toast{background:var(--card);border:1px solid var(--groove2);border-radius:var(--r2);padding:11px 15px;font-size:12px;display:flex;align-items:center;gap:9px;box-shadow:var(--shadow2);animation:toastin .2s ease}@keyframes toastin{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.toast-success{border-left:3px solid var(--pine)}.toast-error{border-left:3px solid var(--fire)}.toast-warning{border-left:3px solid var(--gold-b)}.login-page{min-height:100vh;background:var(--paper);display:flex;align-items:center;justify-content:center;padding:20px;position:relative}.login-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(0,0,0,.05) 1px,transparent 0);background-size:24px 24px;pointer-events:none}.login-card{width:420px;position:relative}.mono{font-family:var(--mono)}.text-pine{color:var(--pine)}.text-fire{color:var(--fire)}.text-gold{color:var(--gold)}.text-ink2{color:var(--ink2)}.text-ink3{color:var(--ink3)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-18{margin-bottom:18px}.fw-700{font-weight:700}.fs-10{font-size:10px}.fs-11{font-size:11px}.fs-12{font-size:12px}.fs-14{font-size:14px}.fs-18{font-size:18px}.fs-20{font-size:20px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
