@import "https://fonts.googleapis.com/css2?family=Noto+Sans+Sinhala:wght@400;500;600;700&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a56db;--primary-dark:#1644b0;--primary-light:#e8f0fe;--sidebar-bg:#1e293b;--sidebar-text:#cbd5e1;--sidebar-active:#2563eb;--danger:#ef4444;--success:#22c55e;--warning:#f59e0b;--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;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f}html,body{height:100%;color:var(--gray-800);background:var(--gray-50);font-family:Noto Sans Sinhala,Segoe UI,system-ui,sans-serif;font-size:15px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--sidebar-bg);z-index:100;flex-direction:column;flex-shrink:0;align-items:center;gap:4px;width:56px;padding:12px 0;display:flex}.sidebar-logo{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:12px;font-size:16px;font-weight:700;text-decoration:none;display:flex}.sidebar-link{width:40px;height:40px;color:var(--sidebar-text);cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;text-decoration:none;transition:background .15s,color .15s;display:flex;position:relative}.sidebar-link:hover{color:#fff;background:#ffffff1a}.sidebar-link.active{background:var(--sidebar-active);color:#fff}.sidebar-tooltip{background:var(--gray-800);color:#fff;white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;z-index:200;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%)translate(-8px);box-shadow:0 4px 12px #00000026}.sidebar-tooltip:before{content:"";border-style:solid;border-width:5px 6px 5px 0;border-color:transparent var(--gray-800) transparent transparent;position:absolute;top:50%;left:-4px;transform:translateY(-50%)}.sidebar-link:hover .sidebar-tooltip{opacity:1;visibility:visible;transform:translateY(-50%)translate(0)}.sidebar-spacer{flex:1}.main-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--gray-200);background:#fff;flex-shrink:0;align-items:center;gap:12px;padding:10px 20px;display:flex}.topbar-title{color:var(--gray-800);font-size:15px;font-weight:600}.topbar-spacer{flex:1}.page-area{flex:1;display:flex;overflow:hidden}.account-panel{border-right:1px solid var(--gray-200);background:#fff;flex-direction:column;flex-shrink:0;width:400px;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid var(--gray-200);background:var(--gray-50);align-items:center;gap:6px;padding:8px 10px;display:flex}.myp-wrap{flex:1;position:relative}.myp-trigger{border:1px solid var(--gray-200);color:var(--gray-700);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border-radius:6px;align-items:center;gap:6px;min-height:34px;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s;display:flex}.myp-trigger:hover{border-color:var(--gray-400)}.myp-trigger:focus,.myp-trigger.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.myp-value{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.myp-caret{color:var(--gray-400);flex-shrink:0;align-items:center;margin-left:auto;transition:transform .15s;display:flex}.myp-trigger.open .myp-caret{color:var(--primary);transform:rotate(180deg)}.myp-dropdown{border:1px solid var(--gray-200);z-index:600;background:#fff;border-radius:10px;min-width:260px;padding:12px;animation:.15s dp-fade-in;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 8px 24px #0000001f}.myp-year-row{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.myp-year-label{color:var(--gray-800);font-size:15px;font-weight:700}.myp-month-grid{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}.myp-month-cell{color:var(--gray-600);cursor:pointer;text-align:center;white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:8px 4px;font-family:inherit;font-size:12px;font-weight:500;transition:all .1s}.myp-month-cell:hover{background:var(--gray-100);color:var(--gray-800)}.myp-month-cell.selected{background:var(--primary);color:#fff}.panel-nav-btn{border:1px solid var(--gray-200);width:30px;height:30px;color:var(--gray-500);cursor:pointer;background:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;transition:all .15s;display:flex}.panel-nav-btn:hover{background:var(--gray-100);border-color:var(--gray-300);color:var(--gray-700)}.panel-nav-btn:active{transform:scale(.95)}.badge-toggle{cursor:pointer;border:1px solid var(--gray-300);color:var(--gray-500);-webkit-user-select:none;user-select:none;background:#fff;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:11px;font-weight:600;transition:all .15s}.badge-toggle:hover{border-color:var(--gray-400);color:var(--gray-700)}.badge-toggle.active{background:var(--primary);color:#fff;border-color:var(--primary)}.badge-toggle.active:hover{opacity:.85}.account-tree{flex:1;padding:6px 0;overflow-y:auto}.group-row{color:var(--gray-700);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;display:flex}.group-row:hover{background:var(--gray-50)}.group-name{text-overflow:ellipsis;white-space:nowrap;flex:1;align-items:center;gap:4px;display:flex;overflow:hidden}.group-balance{color:var(--gray-700);flex-shrink:0;font-size:13px;font-weight:600}.group-balance.negative{color:var(--danger)}.account-row{color:var(--gray-600);cursor:pointer;border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:7px 14px 7px 28px;font-size:13px;display:flex}.account-row:hover{background:var(--gray-50)}.account-row.selected{background:var(--primary-light);color:var(--primary)}.account-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.account-balance{color:var(--gray-600);flex-shrink:0;font-size:13px}.account-balance.negative{color:var(--danger)}.balance-tag{white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.balance-tag-Asset{color:#1a4a6a;background:#bfdced}.balance-tag-Liability{color:#7a5a00;background:#fdeab5}.balance-tag-Incoming{color:#1a5c30;background:#c2e5cc}.balance-tag-Outgoing,.balance-tag-Expense{color:#7a1e14;background:#edb6af}.account-tree-edit{padding:4px 0}.tree-row{align-items:center;gap:6px;min-height:34px;padding:5px 12px;transition:background .1s;display:flex}.tree-row:hover{background:var(--gray-50)}.tree-toggle{cursor:pointer;color:var(--gray-400);background:0 0;border:none;flex-shrink:0;padding:2px 4px}.tree-label{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.tree-group-label{color:var(--gray-700);font-weight:600}.tree-account .tree-label{color:var(--gray-600);font-weight:400}.tree-balance{color:var(--gray-500);white-space:nowrap;margin-left:auto;margin-right:4px;font-size:12px}.tree-actions{opacity:0;flex-shrink:0;gap:2px;transition:opacity .15s;display:flex}.tree-row:hover .tree-actions{opacity:1}.tree-actions button{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:4px;align-items:center;gap:1px;padding:3px 5px;font-size:13px;display:flex}.tree-actions button:hover{background:var(--gray-100);color:var(--gray-700)}.inline-edit-input{flex:1;min-width:120px;height:28px;padding:2px 8px;font-size:13px}.txn-panel{flex-direction:column;flex:1;display:flex;overflow:hidden}.form-bar{border-bottom:1px solid var(--gray-200);background:#fff;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex}.form-bar label{color:var(--gray-500);white-space:nowrap;font-size:13px}.form-bar input,.form-bar select{border:1px solid var(--gray-300);border-radius:var(--radius);color:var(--gray-700);background:#fff;outline:none;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s}.form-bar input:focus,.form-bar select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-bar input:hover,.form-bar select:hover{border-color:var(--gray-400)}.form-bar input[type=number]{width:110px}.form-bar select{min-width:160px;max-width:200px}.form-bar input[type=text]{min-width:180px}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:5px;padding:7px 14px;font-size:13px;font-weight:500;transition:opacity .15s,transform .1s;display:inline-flex}.btn:hover{opacity:.88}.btn:active{transform:scale(.98)}.btn-primary{background:var(--primary);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-ghost{color:var(--gray-600);border:1px solid var(--gray-300);background:0 0}.btn-ghost:hover{background:var(--gray-100)}.btn-icon{border-radius:6px;justify-content:center;width:32px;height:32px;padding:6px}.btn-sm{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.search-bar{border-bottom:1px solid var(--gray-200);background:#fff;align-items:center;gap:10px;padding:8px 16px;display:flex}.search-input{border:1px solid var(--gray-300);border-radius:var(--radius);color:var(--gray-700);background:#fff;outline:none;width:200px;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s}.search-input:hover{border-color:var(--gray-400)}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.txn-list{flex:1;overflow-y:auto}.txn-item{border-bottom:1px solid var(--gray-100);align-items:center;gap:10px;padding:8px 16px;transition:background .1s;display:flex}.txn-item:hover{background:var(--gray-50)}.txn-date{color:var(--gray-400);flex-shrink:0;width:76px;font-size:13px}.txn-from-account{flex-shrink:0;width:300px}.txn-arrow{color:var(--gray-400);text-align:center;flex-shrink:0;width:20px;font-size:14px}.txn-to-account{flex-shrink:0;width:300px}.txn-desc{color:var(--gray-600);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.txn-amount{text-align:right;flex-shrink:0;width:120px;font-family:monospace;font-size:14px;font-weight:600}.txn-user{color:var(--gray-400);text-align:right;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:60px;font-size:12px;overflow:hidden}.txn-lock{color:var(--gray-400);flex-shrink:0;align-items:center;display:flex}.txn-lock.locked{color:#065f46}.txn-lock-btn{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:4px;flex-shrink:0;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.txn-lock-btn:hover{background:var(--gray-100)}.txn-lock-btn.locked{color:#065f46}.txn-lock-btn.locked:hover{color:#92400e}.txn-actions{flex-shrink:0;gap:2px;display:flex}.txn-actions button{cursor:pointer;color:var(--gray-400);background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:14px}.txn-actions button:hover{background:var(--gray-100);color:var(--gray-700)}.status-chip{border-radius:20px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.status-Pending{color:#92400e;background:#fef3c7}.status-Approved{color:#065f46;background:#d1fae5}.status-Rejected{color:#991b1b;background:#fee2e2}.status-ACTIVE{color:#065f46;background:#d1fae5}.status-INACTIVE{color:#64748b;background:#f1f5f9}.account-chip{border-radius:12px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-block}.chip-Asset{color:#1a4a6a;background:#bfdced}.chip-Liability{color:#7a5a00;background:#fdeab5}.chip-Incoming{color:#1a5c30;background:#c2e5cc}.chip-Outgoing,.chip-Expense{color:#7a1e14;background:#edb6af}.card{border-radius:var(--radius);border:1px solid var(--gray-200);box-shadow:var(--shadow);background:#fff}.card-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.card-body{padding:18px}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}th{text-align:left;color:var(--gray-500);background:var(--gray-50);border-bottom:2px solid var(--gray-200);white-space:nowrap;z-index:1;padding:9px 12px;font-size:12px;font-weight:600;position:sticky;top:0}td{border-bottom:1px solid var(--gray-100);padding:9px 12px}tr:hover td{background:var(--gray-50)}.form-group{margin-bottom:14px}.form-group label{color:var(--gray-600);margin-bottom:4px;font-size:12px;font-weight:500;display:block}.form-control{border:1px solid var(--gray-300);border-radius:var(--radius);width:100%;color:var(--gray-700);background:#fff;outline:none;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-control:hover{border-color:var(--gray-400)}select.form-control{appearance:none;cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") right 10px center no-repeat;padding-right:30px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;width:520px;max-width:calc(100vw - 32px);max-height:calc(100vh - 60px);padding:24px;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-title{color:var(--gray-800);justify-content:space-between;align-items:center;margin-bottom:20px;font-size:16px;font-weight:700;display:flex}.modal-footer{border-top:1px solid var(--gray-200);justify-content:flex-end;gap:8px;margin-top:20px;padding-top:16px;display:flex}.confirm-dialog{text-align:center;background:#fff;border-radius:12px;width:360px;max-width:calc(100vw - 32px);padding:28px 24px 20px;box-shadow:0 20px 60px #0003}.confirm-icon{color:var(--danger);margin-bottom:12px}.confirm-msg{color:var(--gray-800);margin:0 0 6px;font-size:15px;font-weight:600}.confirm-detail{color:var(--gray-500);text-overflow:ellipsis;white-space:nowrap;margin:0 0 20px;font-size:13px;overflow:hidden}.confirm-actions{justify-content:center;gap:10px;display:flex}.login-page{background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:16px;width:380px;padding:40px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{background:var(--primary);color:#fff;border-radius:18px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 14px;font-size:26px;font-weight:700;display:flex}.login-title{text-align:center;color:var(--gray-800);font-size:22px;font-weight:700}.login-subtitle{text-align:center;color:var(--gray-400);margin-top:4px;font-size:13px}.login-error{color:#991b1b;border-radius:var(--radius);background:#fee2e2;border:1px solid #fecaca;margin-bottom:16px;padding:10px 14px;font-size:13px}.alert{border-radius:var(--radius);margin-bottom:12px;padding:10px 14px;font-size:13px}.alert-error{color:#991b1b;background:#fee2e2}.alert-success{color:#065f46;background:#d1fae5}.spinner{border:2px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-row{color:var(--gray-400);justify-content:center;align-items:center;gap:10px;padding:40px;display:flex}.page-container{flex:1;padding:20px;overflow-y:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-title{color:var(--gray-800);font-size:18px;font-weight:700}.empty-state{text-align:center;color:var(--gray-400);padding:60px 20px}.empty-state p{margin-top:8px;font-size:13px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.pagination{border-top:1px solid var(--gray-200);justify-content:center;align-items:center;gap:6px;padding:12px;display:flex}.sselect-wrap{width:auto;max-width:100%;display:inline-block;position:relative}.sselect-trigger{border:1px solid var(--gray-300);border-radius:var(--radius);cursor:pointer;white-space:nowrap;background:#fff;align-items:center;gap:5px;width:max-content;min-width:180px;max-width:100%;min-height:32px;padding:5px 8px;font-size:13px;transition:border-color .15s;display:flex;overflow:hidden}.form-bar .sselect-wrap{flex:1;min-width:180px;max-width:280px}.form-bar .sselect-trigger{width:100%;max-width:100%}.sselect-trigger:focus-within,.sselect-trigger.open{border-color:var(--primary)}.sselect-trigger-placeholder{color:var(--gray-400);flex:1;font-size:12px}.sselect-trigger .account-chip{flex:1;min-width:0}.sselect-caret{color:var(--gray-400);flex-shrink:0;margin-left:auto;font-size:10px}.sselect-dropdown{border:1px solid var(--gray-200);border-radius:var(--radius);width:max-content;min-width:100%;box-shadow:var(--shadow-md);z-index:500;background:#fff;position:absolute;top:calc(100% + 3px);left:0;overflow:hidden}.sselect-search{border:none;border-bottom:1px solid var(--gray-100);background:var(--gray-50);outline:none;width:100%;padding:6px 10px;font-size:13px}.sselect-options{max-height:350px;overflow-y:auto}.sselect-option{cursor:pointer;color:var(--gray-700);align-items:center;gap:7px;padding:6px 10px;font-size:13px;transition:background .1s;display:flex}.sselect-option:hover{background:var(--gray-50)}.sselect-option.active{background:var(--primary-light)}.sselect-option.highlighted{background:var(--gray-100)}.sselect-group-header{color:var(--primary);text-transform:uppercase;letter-spacing:.4px;background:var(--primary-light);border-top:2px solid var(--primary);margin-top:4px;padding:7px 10px 5px;font-size:11px;font-weight:700}.sselect-group-header:first-child{border-top:none;margin-top:0}.sselect-empty{color:var(--gray-400);text-align:center;padding:12px 10px;font-size:12px}.sselect-option-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dp-wrap{display:inline-block;position:relative}.dp-wrap.dp-full{display:block}.dp-trigger{border:1px solid var(--gray-300);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;align-items:center;gap:6px;min-width:148px;min-height:34px;padding:7px 10px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,box-shadow .15s;display:flex}.dp-wrap.dp-full .dp-trigger{width:100%}.dp-trigger:hover{border-color:var(--gray-400)}.dp-trigger:focus,.dp-trigger.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.dp-value{color:var(--gray-700);flex:1}.dp-placeholder{color:var(--gray-400);flex:1;font-weight:400}.dp-icon{color:var(--gray-400);flex-shrink:0;align-items:center;margin-left:auto;display:flex}.dp-trigger.open .dp-icon{color:var(--primary)}.dp-dropdown{border:1px solid var(--gray-200);z-index:600;background:#fff;border-radius:10px;width:280px;padding:12px;animation:.15s dp-fade-in;position:absolute;top:calc(100% + 4px);left:0;box-shadow:0 8px 24px #0000001f}@keyframes dp-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dp-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.dp-month-year{color:var(--gray-800);font-size:14px;font-weight:600}.dp-nav{border:1px solid var(--gray-200);width:28px;height:28px;color:var(--gray-500);cursor:pointer;background:#fff;border-radius:6px;justify-content:center;align-items:center;font-size:16px;font-weight:600;transition:all .15s;display:flex}.dp-nav:hover{background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-700)}.dp-days-header{grid-template-columns:repeat(7,1fr);gap:0;margin-bottom:4px;display:grid}.dp-day-label{text-align:center;color:var(--gray-400);padding:4px 0;font-size:11px;font-weight:600}.dp-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.dp-cell{aspect-ratio:1;width:100%;color:var(--gray-700);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-family:inherit;font-size:13px;transition:all .1s;display:flex}.dp-cell:hover:not(.dp-empty){background:var(--gray-100)}.dp-cell.today{border:1.5px solid var(--primary);color:var(--primary);font-weight:600}.dp-cell.selected{background:var(--primary);color:#fff;font-weight:600}.dp-cell.selected.today{border-color:var(--primary)}.dp-empty{cursor:default}.dp-footer{border-top:1px solid var(--gray-100);align-items:center;gap:8px;margin-top:8px;padding-top:8px;display:flex}.dp-today-btn,.dp-clear-btn{cursor:pointer;border:none;border-radius:5px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .15s}.dp-today-btn{background:var(--primary-light);color:var(--primary)}.dp-today-btn:hover{background:#d0e0fd}.dp-clear-btn{background:var(--gray-100);color:var(--gray-500);margin-left:auto}.dp-clear-btn:hover{background:var(--gray-200)}.side-panel-overlay{z-index:900;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0000004d;animation:.15s sp-fade-in;position:fixed;inset:0}@keyframes sp-fade-in{0%{opacity:0}to{opacity:1}}@keyframes sp-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}.side-panel{z-index:950;background:#fff;flex-direction:column;width:460px;max-width:calc(100vw - 56px);height:100vh;animation:.2s sp-slide-in;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 30px #0000001f}.side-panel-header{border-bottom:1px solid var(--gray-200);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.side-panel-title{color:var(--gray-800);font-size:15px;font-weight:700}.side-panel-subtitle{color:var(--gray-400);margin-top:2px;font-size:12px}.side-panel-body{flex:1;padding:16px 20px;overflow-y:auto}.side-panel-footer{border-top:1px solid var(--gray-200);flex-shrink:0;padding:12px 20px}.payment-tag{letter-spacing:.3px;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.payment-tag-paid{color:#065f46;background:#d1fae5}.payment-tag-due{color:#92400e;background:#fef3c7}.payment-tag-unpaid{color:#991b1b;background:#fee2e2}.payment-item{border-bottom:1px solid var(--gray-100);align-items:center;gap:10px;padding:10px 0;display:flex}.payment-item:last-child{border-bottom:none}.payment-year{color:var(--gray-700);flex-shrink:0;width:50px;font-size:14px;font-weight:700}.payment-details{flex:1;min-width:0}.payment-amount{color:var(--gray-800);font-size:14px;font-weight:600}.payment-meta{color:var(--gray-400);margin-top:2px;font-size:11px}.payment-status{flex-shrink:0}.worker-tabs{border-bottom:2px solid var(--gray-200);gap:0;margin-bottom:16px;display:flex}.worker-tab{color:var(--gray-500);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:8px 20px;font-family:inherit;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.worker-tab:hover{color:var(--gray-700)}.worker-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.timesheet-summary{background:var(--gray-50);border-top:1px solid var(--gray-200);gap:24px;padding:14px 16px;display:flex}.summary-item{flex-direction:column;gap:2px;display:flex}.summary-item span{color:var(--gray-500);font-size:11px}.summary-item strong{color:var(--gray-800);font-size:15px;font-weight:700}.scan-result{border-radius:var(--radius);margin-top:12px;padding:14px;font-size:13px;animation:.3s scan-pop}@keyframes scan-pop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.scan-checkin{color:#065f46;background:#d1fae5;border:1px solid #a7f3d0}.scan-checkout{color:#3730a3;background:#e0e7ff;border:1px solid #c7d2fe}.scan-info{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.scan-error{color:#991b1b;background:#fee2e2;border:1px solid #fecaca}
