:root{--brand:#176b5f;--brand2:#0d4c43;--accent:#d08a22;--danger:#a33;--ink:#17212b;--muted:#657386;--line:#cbd5df;--paper:#fff;--bg:#f3f6f8}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Arial,Helvetica,sans-serif;font-size:14px}button,input,select,textarea{font:inherit}button{border:1px solid transparent;border-radius:8px;padding:9px 13px;font-weight:700;cursor:pointer}.primary{background:var(--accent);color:white}.secondary{background:white;color:var(--brand2);border-color:#d8e1e8}.danger,.danger-outline{color:white;background:var(--danger)}.danger-outline{background:white;color:var(--danger);border-color:#e2bbbb}.is-hidden{display:none!important}.login-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand2),var(--brand))}.login-card{width:min(460px,92vw);background:white;border-radius:18px;padding:32px;box-shadow:0 20px 50px #0004;text-align:center}.login-logo{width:120px}.login-card h1{font-size:25px;margin:12px 0 4px}.login-form{display:grid;gap:12px;margin:22px 0;text-align:left}.login-form label,.form-grid label,.role-switch label{display:grid;gap:6px;font-weight:700;color:#334}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px;background:white}textarea{min-height:70px;resize:vertical}.dummy-box{display:grid;gap:4px;text-align:left;background:#f7fafc;border:1px solid #dde6ee;border-radius:12px;padding:12px;color:var(--muted)}.app{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:#102f2a;color:white;padding:18px}.side-brand{display:flex;gap:12px;align-items:center;margin-bottom:18px}.side-brand img{width:56px;height:56px;object-fit:contain;background:white;border-radius:8px;padding:3px}.side-brand span{display:block;font-size:12px;color:#d6eee9}.nav-btn{width:100%;display:block;text-align:left;margin:5px 0;background:#ffffff12;color:white;border-color:#ffffff24}.nav-btn.active{background:var(--accent)}.role-switch{margin:14px 0;padding:12px;border:1px solid #ffffff24;border-radius:10px}.role-switch label{color:white}.main-content{padding:22px}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:18px}.topbar h1{margin:0;font-size:26px}.topbar p{margin:4px 0 0;color:var(--muted)}.top-actions{display:flex;gap:8px;flex-wrap:wrap}.panel{background:white;border:1px solid #dce4eb;border-radius:12px;padding:20px;box-shadow:0 8px 24px #17212b0f}.section-title{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px}.section-title h2{margin:0;font-size:20px}.help{color:var(--muted);font-size:13px;margin:-6px 0 14px}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:14px}.form-grid.two{grid-template-columns:repeat(2,minmax(220px,1fr))}.form-grid.three{grid-template-columns:repeat(3,minmax(180px,1fr))}.status-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px;margin:12px 0}.status-card{border:1px solid #dce4eb;border-radius:10px;padding:12px;background:#fbfcfd}.status-card span{display:block;color:var(--muted);font-size:12px}.status-card strong{display:block;margin-top:4px;color:var(--brand2)}.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border:1px solid var(--line);padding:8px;vertical-align:top}th{background:#edf3f5;text-align:left}.input-table{min-width:1850px}.input-table textarea{min-width:210px}.small{font-size:12px;color:var(--muted)}.notice{border-left:5px solid var(--accent);background:#fff8ec;padding:12px;border-radius:8px;margin:10px 0}.account-row{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid #dce4eb;border-radius:10px;padding:12px;margin:10px 0}.account-row p{margin:4px 0;color:var(--muted)}.account-actions{display:flex;gap:6px}.print-area{display:none}.print-page{background:white;padding:14mm;margin-bottom:12px;page-break-after:always}.print-heading{text-align:center}.print-logo{width:70px}.print-heading h2,.print-heading h3,.print-heading p{margin:2px}.print-address{font-size:11px}.identity-table th{width:20%}.print-table{font-size:12px}.print-footer{display:flex;justify-content:space-between;margin-top:10px;font-size:11px;color:#555}.signature-table{margin-top:20px;width:100%;table-layout:fixed}.signature-table td{text-align:center;height:130px;vertical-align:bottom}.sig-space{height:55px}.signature-table strong,.signature-table span{display:block}.signature-table td{width:50%}.print-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.print-summary div{border:1px solid var(--line);padding:8px;background:#f9fbfc}.print-summary span{display:block;font-size:11px;color:#555}.print-summary strong{font-size:18px}@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.form-grid,.form-grid.two,.form-grid.three,.status-grid{grid-template-columns:1fr}.topbar{display:block}.top-actions{margin-top:12px}}@media print{body{background:white}.no-print,.app,.login-page{display:none!important}.print-area{display:block}.print-page{border:0;margin:0;box-shadow:none}.assessment-hide{display:none!important}@page{size:A4 landscape;margin:10mm}}

/* Revisi 2026-05-17: kepadatan interface dan status aksi */
body{font-size:12.5px;line-height:1.35}
.main-content{padding:16px}.panel{padding:16px}.topbar h1{font-size:21px}.section-title h2{font-size:17px}
button{min-height:32px;padding:6px 10px;border-radius:7px}
input,select,textarea{padding:6px 7px;border-radius:6px;min-height:32px}
textarea{min-height:54px}.form-grid{gap:10px}.status-grid{gap:8px}.status-card{padding:9px}
th,td{padding:5px}.input-table{min-width:1550px}.input-table textarea{min-width:160px}.input-table input[type="number"]{min-width:72px}.input-table select{min-width:145px}
.assessor-only{background:#f0f3f6;color:#687789;cursor:not-allowed}.bottom-actions{justify-content:flex-end;border-top:1px solid #e2e8ef;padding-top:12px;margin-top:18px}
.toast-box{position:fixed;right:20px;bottom:20px;z-index:9999;max-width:360px;background:#123d36;color:#fff;border-radius:10px;padding:12px 14px;box-shadow:0 10px 30px #0004;opacity:0;transform:translateY(10px);pointer-events:none;transition:.2s ease}
.toast-box.show{opacity:1;transform:translateY(0)}
.editable-assessor{background:#fff;color:var(--ink);cursor:text}
.search-box{display:block;margin-bottom:12px;max-width:520px}
.input-table input[type="number"]{min-width:82px}
.table-bottom-actions{justify-content:flex-start;border-top:1px solid #e2e8ef;padding-top:12px;margin-top:12px;margin-bottom:18px}.bottom-submit-actions{justify-content:flex-end;border-top:1px solid #e2e8ef;padding-top:14px;margin-top:18px}


/* Revisi tombol dan batas nilai */
button.save-action{background:#176b5f;color:#fff;border-color:#176b5f}
button.add-action{background:#245f96;color:#fff;border-color:#245f96}
button.submit-action{background:#d08a22;color:#fff;border-color:#d08a22}
button.approve-action{background:#1f7a4d;color:#fff;border-color:#1f7a4d}
button.return-action{background:#fff3d7;color:#8a5700;border-color:#d08a22}
button.secondary{background:#fff;color:#0d4c43;border-color:#cbd5df}
button.danger, button.danger-outline{background:#a33;color:#fff;border-color:#a33}
button.danger-outline{background:#fff;color:#a33;border-color:#d8a7a7}
.table-bottom-actions{justify-content:flex-start;align-items:center;border-top:1px solid #e2e8ef;padding-top:10px;margin-top:10px;margin-bottom:18px}
.bottom-submit-actions{justify-content:flex-end;align-items:center;border-top:1px solid #e2e8ef;padding-top:14px;margin-top:18px}
.doc-title-badge{display:inline-block;margin-top:6px!important;padding:5px 14px;border:1.5px solid #176b5f;background:#eef8f5;border-radius:4px;letter-spacing:.03em;font-size:13px}
@media print{.doc-title-badge{background:#eef8f5!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}

/* Monitoring SKP admin */
.monitoring-filters{margin:12px 0}.monitor-note{margin:10px 0 12px;padding:9px 12px;border:1px solid #dce4eb;background:#fbfcfd;border-radius:8px;color:var(--muted)}.monitor-note strong{color:var(--brand2)}.monitor-table{min-width:1120px}.monitor-table th,.monitor-table td{white-space:nowrap}.monitor-table td:nth-child(2),.monitor-table td:nth-child(3),.monitor-table td:nth-child(4){white-space:normal}.status-badge{display:inline-block;min-width:120px;text-align:center;padding:4px 8px;border-radius:999px;border:1px solid #dce4eb;background:#f4f6f8;color:#506070;font-weight:700}.status-badge.ok{background:#eaf7ef;color:#17623b;border-color:#bfe5cd}.status-badge.wait{background:#fff6df;color:#8a5700;border-color:#efd39a}.status-badge.warn{background:#fff0f0;color:#a33;border-color:#e6b8b8}.status-badge.draft{background:#eef3f7;color:#526273;border-color:#d6e0e8}.monitor-empty{text-align:center;color:var(--muted);padding:16px}

/* Print identity layout */
.top-actions #adminPrintDosen{width:240px;min-height:32px}.print-identity-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:10px 0}.identity-table thead th{text-align:center;background:#dfecef;color:#0d4c43}.print-period-table{margin:8px 0 10px}@media print{.print-identity-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.identity-table th{width:34%}.print-period-table th{width:18%}}

/* Riwayat SKP */
.history-table{min-width:1220px}.history-table td:last-child{white-space:nowrap}
