:root{--bg: #f3f7f9;--surface: #ffffff;--surface-soft: #f8fbfc;--ink: #12232e;--muted: #5b6f7a;--faint: #8ba0ab;--line: #dde8ec;--sidebar: #082c3f;--sidebar-2: #0d4157;--blue: #0e7db0;--blue-dark: #0a6089;--blue-soft: #e0f2fb;--teal: #0e8c86;--mangrove: #2f8f5b;--mangrove-soft: #e4f4ea;--amber: #b07a14;--amber-soft: #fdf3da;--rose: #c2415b;--rose-soft: #fde8ee;--violet: #7155b8;--shadow-sm: 0 1px 2px rgba(8, 44, 63, .06);--shadow-md: 0 16px 32px rgba(8, 44, 63, .1);--primary: var(--blue);--primary-dark: var(--blue-dark);--primary-soft: var(--blue-soft)}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;background:var(--bg);color:var(--ink);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.5}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}.app-container{display:grid;grid-template-columns:250px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#d6e6ee}.sidebar-header{display:flex;align-items:center;gap:12px;min-height:72px;padding:15px 18px;border-bottom:1px solid rgba(255,255,255,.08)}.logo-mark{width:40px;height:40px;flex:0 0 40px;display:grid;place-items:center;border-radius:10px;background:#dff2fb;overflow:hidden}.logo-mark svg{width:28px;height:28px}.sidebar-header h1{margin:0;color:#fff;font-size:1rem;line-height:1.2}.sidebar-header small{display:block;color:var(--faint);font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.sidebar-nav{flex:1;padding:14px 12px;overflow-y:auto}.nav-section{margin:18px 10px 8px;color:#d6e6ee8c;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.nav-section:first-child{margin-top:3px}.nav-item{width:100%;display:flex;align-items:center;gap:10px;min-height:40px;padding:9px 10px;border:0;border-radius:8px;background:transparent;color:#d6e6ee;text-align:left;font-weight:600;text-decoration:none}.nav-item .nav-ico{width:22px;text-align:center;font-size:1.05rem}.nav-item:hover,.nav-item.active{background:#ffffff17;color:#fff}.nav-item.active{box-shadow:inset 3px 0 #6fd3a8}.nav-item .nav-badge{margin-left:auto;min-width:20px;padding:1px 6px;border-radius:999px;background:var(--rose);color:#fff;font-size:.7rem;font-weight:800;text-align:center}.nav-item .nav-badge:empty{display:none}.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.08);color:#d6e6eeb8;font-size:.78rem}.main-content{min-width:0;display:flex;flex-direction:column}.top-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:64px;padding:10px 24px;background:#fffffff0;border-bottom:1px solid var(--line);backdrop-filter:blur(12px)}.page-title{margin:0;font-size:1.05rem}.page-title small{display:block;color:var(--muted);font-size:.74rem;font-weight:500}.header-actions{display:flex;align-items:center;gap:10px}.role-switcher{display:flex;align-items:center;gap:8px;padding:5px 8px 5px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.role-switcher span{color:var(--muted);font-size:.68rem;font-weight:800;text-transform:uppercase;white-space:nowrap}.role-switcher select{max-width:200px;border:0;outline:0;background:transparent;font-weight:700}.net-status{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;border:1px solid var(--line);background:var(--surface);color:var(--muted);font-size:.72rem;font-weight:700;white-space:nowrap}.net-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--mangrove)}.net-status.offline{color:var(--amber)}.net-status.offline:before{background:var(--amber)}.workspace{width:min(1180px,100%);padding:26px 26px 90px;margin:0 auto}.pill,.status-chip{display:inline-flex;align-items:center;gap:6px;min-height:24px;padding:2px 9px;border-radius:999px;background:var(--surface);border:1px solid var(--line);color:var(--muted);font-size:.72rem;font-weight:700;white-space:nowrap}.status-chip.info{background:var(--blue-soft);color:var(--blue-dark);border-color:transparent}.status-chip.success{background:var(--mangrove-soft);color:var(--mangrove);border-color:transparent}.status-chip.warning{background:var(--amber-soft);color:var(--amber);border-color:transparent}.status-chip.danger{background:var(--rose-soft);color:var(--rose);border-color:transparent}.panel{border:1px solid var(--line);border-radius:12px;background:var(--surface);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:18px}.panel-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--surface-soft)}.panel-header h3{margin:0;font-size:.98rem}.panel-header p{margin:2px 0 0;color:var(--muted);font-size:.8rem;width:100%}.panel-body{padding:16px 18px}.hero-panel{border:1px solid var(--line);border-radius:14px;background:radial-gradient(1200px 300px at 110% -40%,rgba(14,125,176,.12),transparent),var(--surface);box-shadow:var(--shadow-sm);padding:20px;margin-bottom:18px}.hero-panel h2{margin:0 0 6px;font-size:clamp(1.25rem,2.4vw,1.6rem);line-height:1.2}.hero-panel p{margin:0;color:var(--muted);font-size:.9rem;max-width:720px}.kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.kpi{border:1px solid var(--line);border-radius:12px;background:var(--surface);box-shadow:var(--shadow-sm);padding:13px 15px;border-top:3px solid var(--primary)}.kpi.tone-committed{border-top-color:var(--amber)}.kpi.tone-actual{border-top-color:var(--mangrove)}.kpi.tone-sisa{border-top-color:var(--faint)}.kpi strong{display:block;font-size:1.12rem;line-height:1.2;word-break:break-word}.kpi span{display:block;color:var(--muted);font-size:.76rem;margin-bottom:3px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.kpi small{display:block;color:var(--faint);font-size:.72rem;margin-top:3px}.budget-bar{position:relative;height:10px;border-radius:999px;background:#e6eef2;overflow:hidden}.budget-bar .seg{position:absolute;inset:0 auto 0 0;border-radius:999px}.budget-bar .seg.committed{background:var(--amber);opacity:.55}.budget-bar .seg.actual{background:var(--mangrove)}.budget-bar.over .seg.actual{background:var(--rose)}.bar-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;color:var(--muted);font-size:.72rem}.bar-legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}.bar-legend .lg-actual i{background:var(--mangrove)}.bar-legend .lg-committed i{background:var(--amber);opacity:.6}.bar-legend .lg-sisa i{background:#e6eef2;border:1px solid var(--line)}.table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;min-width:560px}.data-table th,.data-table td{padding:11px 14px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.data-table th{color:var(--muted);background:var(--surface-soft);font-size:.68rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.data-table td{font-size:.85rem}.data-table tr:last-child td{border-bottom:0}.data-table td.num,.data-table th.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}.primary-cell strong{display:block}.primary-cell span{display:block;color:var(--muted);font-size:.76rem}.row-toggle{background:transparent;border:0;padding:0;font:inherit;font-weight:700;color:var(--ink);display:flex;gap:8px;align-items:baseline;text-align:left}.row-toggle:before{content:"▸";color:var(--faint);transition:transform .15s;display:inline-block}.row-toggle.open:before{transform:rotate(90deg)}.empty-state{padding:30px 18px;text-align:center;color:var(--muted);font-size:.88rem}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid .full{grid-column:1 / -1}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:.78rem;font-weight:700;color:var(--muted)}.form-group label .req{color:var(--rose)}.form-control{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;background:var(--surface);outline:none;font-size:.92rem;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0e7db024}.form-control.ocr-filled{border-color:var(--teal);background:#f0faf9}textarea.form-control{resize:vertical;min-height:70px}.form-hint{color:var(--faint);font-size:.72rem}.btn-primary,.btn-secondary,.btn-ghost,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 16px;border-radius:8px;text-decoration:none;font-weight:700;font-size:.9rem;border:1px solid transparent}.btn-primary{background:var(--primary);border-color:var(--primary-dark);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:#fff;border-color:var(--line);color:var(--ink)}.btn-secondary:hover{background:var(--surface-soft)}.btn-ghost{background:transparent;color:var(--primary-dark)}.btn-danger{background:#fff;border-color:var(--rose);color:var(--rose)}.btn-sm{min-height:32px;padding:0 12px;font-size:.8rem}.file-upload{border:2px dashed var(--line);padding:22px 16px;text-align:center;border-radius:10px;cursor:pointer;background:var(--surface-soft);transition:border-color .15s,background .15s;color:var(--muted);font-size:.88rem}.file-upload:hover,.file-upload.dragover{border-color:var(--primary);background:var(--blue-soft)}.file-upload .up-ico{font-size:1.6rem;display:block;margin-bottom:6px}.file-upload img.preview{max-width:100%;max-height:220px;border-radius:8px;display:block;margin:0 auto 8px}.ocr-status{display:none;align-items:center;gap:10px;margin-top:10px;padding:10px 12px;border-radius:8px;font-size:.82rem;font-weight:600}.ocr-status.show{display:flex}.ocr-status.loading{background:var(--blue-soft);color:var(--blue-dark)}.ocr-status.done{background:var(--mangrove-soft);color:var(--mangrove)}.ocr-status.error{background:var(--amber-soft);color:var(--amber)}.spinner{width:16px;height:16px;flex:0 0 16px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.approval-flow{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line);color:var(--muted);font-size:.78rem}.approval-flow .flow-step{display:inline-flex;align-items:center;gap:5px;font-weight:600}.approval-flow .flow-step.now{color:var(--primary-dark)}.approval-flow .arrow{color:var(--faint)}.queue-card{border:1px solid var(--line);border-radius:12px;background:var(--surface);padding:14px 16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.queue-card .q-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;align-items:baseline}.queue-card h4{margin:0;font-size:.95rem}.queue-card .q-meta{color:var(--muted);font-size:.78rem;margin:4px 0 10px}.queue-card .q-amount{font-weight:800;font-variant-numeric:tabular-nums}.queue-card .q-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.queue-card .q-note{flex:1 1 200px}.queue-card img.bukti-thumb{max-height:120px;border-radius:8px;border:1px solid var(--line);cursor:zoom-in;margin-bottom:10px}.tabs{display:flex;gap:8px;margin-bottom:14px;overflow-x:auto}.tab-btn{border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 15px;font-weight:700;font-size:.82rem;color:var(--muted);white-space:nowrap}.tab-btn.active{background:var(--sidebar);border-color:var(--sidebar);color:#fff}.tab-btn .cnt{margin-left:6px;font-weight:800}.toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%) translateY(20px);background:var(--sidebar);color:#fff;padding:11px 18px;border-radius:10px;font-size:.86rem;font-weight:600;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:90;max-width:min(480px,90vw);text-align:center}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}dialog.bf-modal{border:0;border-radius:14px;padding:0;max-width:min(560px,92vw);box-shadow:var(--shadow-md)}dialog.bf-modal::backdrop{background:#082c3f80}dialog.bf-modal .modal-body{padding:18px}dialog.bf-modal img{max-width:100%;border-radius:8px}.bottom-nav{display:none;position:fixed;inset:auto 0 0;z-index:30;background:#fffffff7;border-top:1px solid var(--line);backdrop-filter:blur(12px);padding:4px 4px calc(4px + env(safe-area-inset-bottom))}.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;padding:6px 2px;border-radius:10px;color:var(--muted);text-decoration:none;font-size:.62rem;font-weight:700;position:relative}.bottom-nav a .nav-ico{font-size:1.15rem}.bottom-nav a.active{color:var(--primary-dark);background:var(--blue-soft)}.bottom-nav a .nav-badge{position:absolute;top:2px;right:calc(50% - 20px);min-width:16px;height:16px;padding:0 4px;display:grid;place-items:center;border-radius:999px;background:var(--rose);color:#fff;font-size:.6rem}.bottom-nav a .nav-badge:empty{display:none}@media(max-width:900px){.app-container{display:block}.sidebar{display:none}.bottom-nav{display:flex}.workspace{padding:18px 14px 96px}.top-header{padding:10px 14px}.kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid{grid-template-columns:1fr}.page-title{font-size:.98rem}.role-switcher span{display:none}.role-switcher select{max-width:150px}.net-status{font-size:0;gap:0;padding:5px 7px}.net-status:before{margin:0}}@media(max-width:480px){.kpi-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.kpi strong{font-size:.98rem}}
