@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;700&family=JetBrains+Mono:wght@400;500&display=swap");:root{--bg:#f5f4f0;--bg2:#fff;--bg3:#edecea;--bg4:#e4e3df;--border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.14);--text:#1a1a18;--text2:#5a5955;--text3:#9a9892;--teal:#0f7a62;--teal-bg:rgba(15,122,98,.07);--teal-border:rgba(15,122,98,.22);--purple:#5b47c4;--purple-bg:rgba(91,71,196,.07);--purple-border:rgba(91,71,196,.22);--blue:#1a5fa8;--blue-bg:rgba(26,95,168,.07);--blue-border:rgba(26,95,168,.22);--amber:#a05f0a;--amber-bg:rgba(160,95,10,.07);--amber-border:rgba(160,95,10,.22);--red:#b83030;--red-bg:rgba(184,48,48,.07);--red-border:rgba(184,48,48,.22);--green:#2d7a1f;--green-bg:rgba(45,122,31,.07);--green-border:rgba(45,122,31,.22);--gray-bg:rgba(90,89,85,.06)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Noto Sans SC,sans-serif;font-size:14px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}.topbar{height:52px;background:var(--bg2);border-bottom:1px solid var(--border);justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100}.logo,.topbar{display:flex;align-items:center}.logo{gap:10px;font-size:15px;font-weight:700;letter-spacing:-.3px}.logo-dot{width:10px;height:10px;border-radius:3px;background:var(--teal)}.role-switcher{display:flex;gap:4px;background:var(--bg3);border-radius:10px;padding:3px}.role-btn{padding:5px 14px;border-radius:8px;border:none;background:transparent;color:var(--text2);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:6px;white-space:nowrap}.role-btn.active,.role-btn:hover{color:var(--text);background:var(--bg2)}.role-btn.active{font-weight:500;box-shadow:0 1px 3px rgba(0,0,0,.06)}.role-btn.active.r-procurement{background:var(--teal-bg);color:var(--teal);border:1px solid var(--teal-border)}.role-btn.active.r-settlement{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-border)}.role-btn.active.r-finance{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}.role-btn.active.r-payment{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}.role-btn.active.r-all{background:var(--bg2);color:var(--text);border:1px solid var(--border2);box-shadow:0 1px 3px rgba(0,0,0,.06)}.role-dot{width:7px;height:7px;border-radius:50%}.r-procurement .role-dot{background:var(--teal)}.r-settlement .role-dot{background:var(--purple)}.r-finance .role-dot{background:var(--blue)}.r-payment .role-dot{background:var(--amber)}.r-all .role-dot{background:var(--text2)}.main{display:flex;height:calc(100vh - 52px)}.sidebar{width:220px;min-width:220px;background:var(--bg2);border-right:1px solid var(--border);padding:16px 10px;overflow-y:auto}.sidebar-section{margin-bottom:20px}.sidebar-label{font-size:11px;font-weight:500;color:var(--text3);letter-spacing:.8px;text-transform:uppercase;padding:8px 8px 6px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;cursor:pointer;color:var(--text2);font-size:13px;transition:all .15s;margin-bottom:2px}.sidebar-item.active,.sidebar-item:hover{background:var(--bg3);color:var(--text)}.sidebar-item.active{font-weight:500}.sidebar-badge{margin-left:auto;background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);font-size:11px;font-family:JetBrains Mono,monospace;padding:1px 6px;border-radius:4px}.sidebar-badge.amber{background:var(--amber-bg);border-color:var(--amber-border);color:var(--amber)}.sidebar-badge.green{background:var(--green-bg);border-color:var(--green-border);color:var(--green)}.content{flex:1;overflow-y:auto;padding:24px 28px}.view-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.view-title{font-size:20px;font-weight:700;letter-spacing:-.5px;margin-bottom:4px}.view-subtitle{font-size:13px;color:var(--text2)}.header-actions{display:flex;gap:8px}.btn{padding:8px 16px;border-radius:8px;border:1px solid var(--border2);background:var(--bg3);color:var(--text);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg4);border-color:var(--border2)}.btn-primary{background:var(--teal);color:#0f1117;border-color:var(--teal);font-weight:600}.btn-primary:hover{opacity:.9}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 20px;transition:border-color .2s}.kpi-card:hover{border-color:var(--border2)}.kpi-label{font-size:12px;color:var(--text2);margin-bottom:8px;display:flex;align-items:center;gap:6px}.kpi-value{font-size:22px;font-weight:700;font-family:JetBrains Mono,monospace;letter-spacing:-1px;color:var(--text)}.kpi-sub{font-size:12px;color:var(--text3);margin-top:4px}.kpi-card.danger{border-color:var(--red-border)}.kpi-card.danger .kpi-value{color:var(--red)}.kpi-card.success .kpi-value{color:var(--green)}.kpi-card.warn .kpi-value{color:var(--amber)}.filter-bar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.filter-chip{padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}.filter-chip:hover{border-color:var(--border2);color:var(--text)}.filter-chip.active{border-color:var(--teal-border);background:var(--teal-bg);color:var(--teal)}.search-input{flex:1;min-width:180px;padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg2);color:var(--text);font-size:13px;font-family:inherit;outline:none}.search-input:focus{border-color:var(--border2)}.search-input::placeholder{color:var(--text3)}.table-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;padding:12px 14px;font-size:11px;font-weight:500;color:var(--text3);letter-spacing:.5px;text-transform:uppercase;background:var(--bg3);white-space:nowrap}tbody tr,thead th{border-bottom:1px solid var(--border)}tbody tr{transition:background .1s;cursor:pointer}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:var(--bg3)}td{padding:12px 14px;font-size:13px;vertical-align:middle}.cell-supplier{font-weight:600;color:var(--text)}.cell-amount{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text);text-align:right}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:500;white-space:nowrap}.badge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.badge-paid{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}.badge-pending{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}.badge-blocked{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}.badge-process{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}.badge-done{background:var(--teal-bg);color:var(--teal);border:1px solid var(--teal-border)}.badge-skip{background:var(--gray-bg);color:var(--text3);border:1px solid var(--border)}.pipeline{gap:0}.pipe-step,.pipeline{display:flex;align-items:center}.pipe-step{width:22px;height:22px;border-radius:50%;justify-content:center;font-size:10px;font-weight:700;position:relative;flex-shrink:0}.pipe-step.done{background:var(--teal-bg);color:var(--teal);border:1px solid var(--teal-border)}.pipe-step.active{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}.pipe-step.todo{background:var(--bg4);color:var(--text3);border:1px solid var(--border)}.pipe-step.blocked{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}.pipe-line{flex:1;height:1px;background:var(--border);min-width:6px;max-width:14px}.pipe-line.done{background:var(--teal);opacity:.4}.action-btn{padding:4px 10px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size:11px;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.action-btn:hover{background:var(--bg4);color:var(--text);border-color:var(--border2)}.action-btn.primary-action{background:var(--teal-bg);color:var(--teal);border-color:var(--teal-border)}.action-btn.primary-action:hover{opacity:.8}.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}.kanban-col{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}.kanban-col-header{padding:12px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.kanban-col-count{font-family:JetBrains Mono,monospace;font-size:12px;color:var(--text2)}.kanban-item{padding:10px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.kanban-item:last-child{border-bottom:none}.kanban-item:hover{background:var(--bg3)}.kanban-supplier{font-size:13px;font-weight:600;margin-bottom:2px}.kanban-project{font-size:11px;color:var(--text2);margin-bottom:6px}.kanban-amount{font-size:12px;font-family:JetBrains Mono,monospace}.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:999;align-items:center;justify-content:center}.modal-overlay.open{display:flex}.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:16px;width:640px;max-height:80vh;overflow-y:auto;padding:28px;box-shadow:0 8px 40px rgba(0,0,0,.14)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.modal-title{font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:var(--text2);font-size:20px;cursor:pointer;line-height:1}.modal-close:hover{color:var(--text)}.modal-section-title{font-size:11px;font-weight:600;color:var(--text3);letter-spacing:.8px;text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.modal-row{display:flex;gap:24px;margin-bottom:20px}.modal-field{flex:1}.modal-field label{display:block;font-size:11px;color:var(--text2);margin-bottom:5px}.modal-val{font-size:13px;font-weight:500;color:var(--text)}.modal-select{cursor:pointer}.modal-select,.modal-textarea{width:100%;padding:8px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;font-family:inherit}.modal-textarea{min-height:70px;resize:vertical}.modal-input{width:100%;padding:8px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;font-family:inherit;outline:none}.modal-input:focus{border-color:var(--border2)}.modal-input::placeholder{color:var(--text3)}.modal-input-amount{width:100%;padding:8px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:13px;font-family:JetBrains Mono,monospace;outline:none}.modal-input-amount:focus{border-color:var(--border2)}.modal-input-amount::placeholder{color:var(--text3);font-family:Noto Sans SC,sans-serif}.field-required:after{content:" *";color:var(--red)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.timeline{display:flex;flex-direction:column;gap:0}.tl-item{display:flex;gap:14px;padding-bottom:16px;position:relative}.tl-item:not(:last-child):before{content:"";position:absolute;left:11px;top:24px;bottom:0;width:1px;background:var(--border)}.tl-dot{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;margin-top:1px}.tl-done{background:var(--teal-bg);border:1px solid var(--teal-border);color:var(--teal)}.tl-active{background:var(--blue-bg);border:1px solid var(--blue-border);color:var(--blue)}.tl-todo{background:var(--bg4);border:1px solid var(--border);color:var(--text3)}.tl-blocked{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red)}.tl-content{flex:1}.tl-title{font-size:13px;font-weight:600;margin-bottom:2px}.tl-desc{font-size:12px;color:var(--text2)}.tl-time{font-size:11px;color:var(--text3);font-family:JetBrains Mono,monospace}.view-panel{display:none}.view-panel.active{display:block}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg2);border:1px solid var(--teal-border);color:var(--teal);padding:12px 20px;border-radius:10px;font-size:13px;font-weight:500;z-index:9999;transform:translateY(80px);opacity:0;transition:all .3s ease;pointer-events:none;box-shadow:0 4px 16px rgba(0,0,0,.12)}.toast.show{transform:translateY(0);opacity:1}.month-tabs{display:flex;gap:4px;margin-bottom:20px}.month-tab{padding:6px 16px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text2);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}.month-tab.active,.month-tab:hover{border-color:var(--border2);color:var(--text)}.month-tab.active{background:var(--bg3);font-weight:500}.loading-wrap{display:flex;align-items:center;justify-content:center;height:300px;color:var(--text3);font-size:14px;gap:10px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:900px){.kanban,.kpi-grid{grid-template-columns:repeat(2,1fr)}.sidebar{width:200px;min-width:200px}}@media (max-width:700px){.sidebar{display:none}.kanban,.kpi-grid{grid-template-columns:1fr}}