:root{--bg-page:#f5f6f7;--bg-card:#fff;--bg-hover:#f5f9ff;--bg-active:#eef4ff;--border-color:#e2e5e9;--text-primary:#1b2534;--text-secondary:#3b4554;--text-muted:#7e8d9f;--text-faint:#9eaab7;--accent:#1565c0;--accent-hover:#0d47a1;--input-border:#c8ced7;--navbar-bg:#fff;--sidebar-bg:#fff}[data-theme=dark]{--bg-page:#0f1117;--bg-card:#1a1d27;--bg-hover:#1e2235;--bg-active:#1a2540;--border-color:#2a2d3d;--text-primary:#e2e8f0;--text-secondary:#c4cdd8;--text-muted:#7e8d9f;--text-faint:#525f72;--accent:#42a5f5;--accent-hover:#1e88e5;--input-border:#3a3f52;--navbar-bg:#13161f;--sidebar-bg:#13161f}:root{--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/145% var(--sans);letter-spacing:.18px;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{box-sizing:border-box;width:100%;min-height:100svh}html,body{max-width:100vw;margin:0;overflow-x:hidden}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}html,body,#root{width:100%;height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.login-page{width:100%;max-width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.login-left{background:var(--bg-card);flex-direction:column;flex:1;justify-content:center;padding:60px 56px;display:flex}.login-logo{align-items:center;gap:10px;margin-bottom:48px;text-decoration:none;display:flex}.login-logo-icon{background-color:var(--accent);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.login-logo-icon svg{fill:#fff;width:22px;height:22px}.login-logo-text{color:var(--text-primary);letter-spacing:-.3px;font-size:22px;font-weight:700}.login-left h1{color:var(--text-primary);margin-bottom:8px;font-size:26px;font-weight:700}.login-subtitle{color:var(--text-muted);margin-bottom:36px;font-size:14px}.login-error{color:#ff4d4f;background:#ff4d4f14;border:1px solid #ff4d4f66;border-radius:5px;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:13px;display:flex}.login-form{flex-direction:column;gap:18px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.login-field input{border:1px solid var(--input-border);height:42px;color:var(--text-primary);background:var(--bg-card);border-radius:5px;outline:none;width:100%;padding:0 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.login-field input::placeholder{color:var(--text-faint)}.login-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff2e}.login-forgot{justify-content:flex-end;margin-top:-10px;display:flex}.login-forgot a{color:var(--accent);font-size:13px;text-decoration:none}.login-forgot a:hover{text-decoration:underline}.login-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:5px;justify-content:center;align-items:center;gap:8px;width:100%;height:42px;margin-top:4px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.login-submit:hover:not(:disabled){background:var(--accent-hover)}.login-submit:disabled{opacity:.65;cursor:not-allowed}.login-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{color:var(--text-muted);margin-top:28px;font-size:13px}.login-footer a{color:var(--accent);font-weight:500;text-decoration:none}.login-footer a:hover{text-decoration:underline}.login-right{background:linear-gradient(145deg,#1565c0 0%,#0d47a1 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:60px 48px;display:flex;position:relative;overflow:hidden}.login-right:before{content:"";background:#ffffff0d;border-radius:50%;width:480px;height:480px;position:absolute;top:-120px;right:-120px}.login-right:after{content:"";background:#ffffff0d;border-radius:50%;width:320px;height:320px;position:absolute;bottom:-80px;left:-80px}.login-right-content{z-index:1;text-align:center;max-width:420px;position:relative}.login-right-icon{background:#ffffff26;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 32px;display:flex}.login-right-icon svg{fill:#fff;width:38px;height:38px}.login-right-content h2{color:#fff;margin-bottom:16px;font-size:28px;font-weight:700;line-height:1.3}.login-right-content p{color:#ffffffbf;margin-bottom:40px;font-size:15px;line-height:1.7}.login-features{text-align:left;flex-direction:column;gap:14px;list-style:none;display:flex}.login-features li{color:#ffffffe6;align-items:center;gap:12px;font-size:14px;display:flex}.login-features li:before{content:"";background:#fff3 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") 50%/13px no-repeat;border-radius:50%;flex-shrink:0;width:20px;height:20px}@media (width<=768px){.login-page{flex-direction:column}.login-left{flex:none;width:100%;padding:40px 24px}.login-right{flex:none;width:100%;padding:48px 24px}.login-field input{width:100%;max-width:100%}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.register-page{width:100%;max-width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.register-panel-brand{background:linear-gradient(145deg,#1565c0 0%,#0d47a1 100%);flex-direction:column;flex:0 0 380px;justify-content:center;align-items:center;padding:60px 48px;display:flex;position:relative;overflow:hidden}.register-panel-brand:before{content:"";background:#ffffff0d;border-radius:50%;width:480px;height:480px;position:absolute;top:-120px;right:-120px}.register-panel-brand:after{content:"";background:#ffffff0d;border-radius:50%;width:320px;height:320px;position:absolute;bottom:-80px;left:-80px}.register-brand-content{z-index:1;text-align:center;position:relative}.register-brand-icon{background:#ffffff26;border-radius:20px;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 28px;display:flex}.register-brand-icon svg{fill:#fff;width:38px;height:38px}.register-brand-content h2{color:#fff;margin-bottom:14px;font-size:24px;font-weight:700;line-height:1.3}.register-brand-content p{color:#ffffffbf;margin-bottom:36px;font-size:14px;line-height:1.7}.register-steps{text-align:left;flex-direction:column;gap:14px;list-style:none;display:flex}.register-steps li{color:#ffffffe0;align-items:center;gap:12px;font-size:13.5px;display:flex}.register-steps li:before{content:"";background:#fff3 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E") 50%/13px no-repeat;border-radius:50%;flex-shrink:0;width:20px;height:20px}.register-panel-form{background:var(--bg-card);flex-direction:column;flex:1;padding:48px 56px;display:flex;overflow-y:auto}.register-logo{align-items:center;gap:10px;margin-bottom:36px;text-decoration:none;display:flex}.register-logo-icon{background-color:var(--accent);border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.register-logo-icon svg{fill:#fff;width:20px;height:20px}.register-logo-text{color:var(--text-primary);letter-spacing:-.3px;font-size:20px;font-weight:700}.register-panel-form h1{color:var(--text-primary);margin-bottom:6px;font-size:24px;font-weight:700}.register-subtitle{color:var(--text-muted);margin-bottom:32px;font-size:13.5px}.register-error{color:#ff4d4f;background:#ff4d4f14;border:1px solid #ff4d4f66;border-radius:5px;align-items:flex-start;gap:10px;margin-bottom:20px;padding:12px 14px;font-size:13px;display:flex}.register-success{color:#389e0d;text-align:center;background:#52c41a14;border:1px solid #52c41a66;border-radius:5px;margin-bottom:20px;padding:20px;font-size:14px}.register-section-title{letter-spacing:.7px;text-transform:uppercase;color:var(--text-faint);border-bottom:1px solid var(--border-color);margin-bottom:14px;padding-bottom:8px;font-size:11px;font-weight:600}.register-form{flex-direction:column;gap:24px;max-width:680px;display:flex}.register-section{flex-direction:column;gap:16px;display:flex}.register-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.register-field{flex-direction:column;gap:5px;display:flex}.register-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.register-field input,.register-field select{border:1px solid var(--input-border);height:40px;color:var(--text-primary);background:var(--bg-card);border-radius:5px;outline:none;width:100%;padding:0 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.register-field input::placeholder{color:var(--text-faint)}.register-field input:focus,.register-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff2e}.register-location-box{border:1px solid var(--border-color);background:var(--bg-page);height:40px;color:var(--text-primary);border-radius:5px;align-items:center;gap:10px;padding:0 12px;font-size:14px;display:flex}.register-location-badge{letter-spacing:.4px;color:var(--accent);background:#4d9fff1a;border-radius:3px;flex-shrink:0;padding:2px 6px;font-size:11px;font-weight:600}.register-location-unknown{color:var(--text-faint);font-size:13px;font-style:italic}.register-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:5px;justify-content:center;align-items:center;gap:8px;width:100%;max-width:680px;height:42px;margin-top:8px;font-size:14px;font-weight:600;transition:background .15s;display:flex}.register-submit:hover:not(:disabled){background:var(--accent-hover)}.register-submit:disabled{opacity:.65;cursor:not-allowed}.register-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite reg-spin}@keyframes reg-spin{to{transform:rotate(360deg)}}.register-footer{color:var(--text-muted);max-width:680px;margin-top:24px;font-size:13px}.register-footer a{color:var(--accent);font-weight:500;text-decoration:none}.register-footer a:hover{text-decoration:underline}@media (width<=960px){.register-panel-brand{display:none}}@media (width<=600px){.register-panel-form{padding:32px 20px}.register-row{grid-template-columns:1fr}}.app-layout{background:var(--bg-page);max-width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border-color);z-index:200;flex-direction:column;flex-shrink:0;width:240px;height:100vh;transition:width .25s,transform .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:60px}.sidebar-brand{border-bottom:1px solid var(--border-color);white-space:nowrap;align-items:center;gap:10px;min-height:60px;padding:16px 12px;display:flex;overflow:hidden}.sidebar-brand-logo{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-brand-name{color:var(--text-primary);letter-spacing:-.2px;white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.sidebar-nav{flex:1;padding:12px 0;overflow:hidden auto}.sidebar-section-title{color:var(--text-faint);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;padding:12px 20px 6px;font-size:10px;font-weight:600}.sidebar-nav-item{color:var(--text-secondary);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 20px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;overflow:hidden}.sidebar-nav-item:hover{background:var(--bg-hover);color:var(--accent)}.sidebar-nav-item.active{background:var(--bg-active);color:var(--accent);font-weight:600}.sidebar-nav-icon{width:18px;height:18px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-nav-item:hover .sidebar-nav-icon,.sidebar-nav-item.active .sidebar-nav-icon{color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border-color);flex-direction:column;gap:2px;padding:12px 0;display:flex;overflow:hidden}.sidebar-user{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;padding:4px 20px 8px;font-size:12px;overflow:hidden}.sidebar-logout-btn{color:var(--text-secondary)}.sidebar-logout-btn:hover{color:#ff4d4f;background:#ff4d4f14}.sidebar-collapse-btn{color:var(--text-faint);cursor:pointer;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 20px;font-size:13px;font-weight:500;transition:background .12s,color .12s;display:flex;overflow:hidden}.sidebar-collapse-btn:hover{background:var(--bg-page);color:var(--text-secondary)}.app-main{flex-direction:column;flex:1;min-width:0;min-height:100vh;margin-left:240px;transition:margin-left .25s;display:flex;overflow-x:hidden}.sidebar-collapsed .app-main{margin-left:60px}.app-navbar{background:var(--navbar-bg);border-bottom:1px solid var(--border-color);z-index:100;align-items:center;gap:12px;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.app-navbar-hamburger{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;padding:4px;transition:background .12s;display:none}.app-navbar-hamburger:hover{background:var(--bg-hover)}.app-navbar-title{color:var(--text-primary);font-size:15px;font-weight:600}.app-navbar-company{color:var(--text-muted);margin-left:auto;font-size:13px}.app-theme-toggle{border:1px solid var(--border-color);background:var(--bg-card);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,color .15s;display:flex}.app-theme-toggle:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.app-content{flex:1;padding:28px}.sidebar-overlay{z-index:199;background:#0006;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{width:240px;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.visible{display:block}.app-main{margin-left:0!important}.app-navbar-hamburger{justify-content:center;align-items:center;display:flex}.sidebar-collapse-btn{display:none}.app-content{padding:16px}}.dashboard-loading{background:var(--bg-page);justify-content:center;align-items:center;min-height:100vh;display:flex}.dashboard-spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.dashboard-error{color:#c0392b;background:var(--bg-page);justify-content:center;align-items:center;min-height:100vh;font-size:15px;display:flex}.dashboard-stats{grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr));gap:16px;margin-bottom:20px;display:grid}.dashboard-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:6px;padding:24px 20px;display:flex}.dashboard-stat-value{color:var(--accent);font-size:32px;font-weight:700;line-height:1}.dashboard-stat-label{color:var(--text-muted);font-size:13px}.dashboard-financials{grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr));gap:16px;margin-bottom:24px;display:grid}.dashboard-financial-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:6px;padding:20px;display:flex}.dashboard-financial-value{color:var(--text-primary);font-size:20px;font-weight:600}.dashboard-financial-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:12px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-title{color:var(--text-primary);margin:0;font-size:20px;font-weight:700}.page-error{color:#ff4d4f;background:#ff4d4f14;border:1px solid #ff4d4f59;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;height:38px;padding:0 18px;font-size:13.5px;font-weight:600;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{height:38px;color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;padding:0 18px;font-size:13.5px;font-weight:500;transition:background .15s,border-color .15s}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.btn-danger{color:#fff;cursor:pointer;background:#e53935;border:none;border-radius:6px;height:38px;padding:0 18px;font-size:13.5px;font-weight:600;transition:background .15s}.btn-danger:hover:not(:disabled){background:#c62828}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.action-btns{gap:6px;display:flex}.btn-icon{border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;width:30px;height:30px;color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s;display:flex}.btn-edit:hover{background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.btn-delete:hover{color:#ff4d4f;background:#ff4d4f14;border-color:#ff4d4f}.table-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;overflow:auto hidden}.table-loading,.table-empty{color:var(--text-muted);justify-content:center;align-items:center;padding:60px 20px;font-size:14px;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.data-table{border-collapse:collapse;width:100%;font-size:13.5px}.data-table th{background:var(--bg-page);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}.data-table td{color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle;padding:12px 16px}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--bg-hover)}.pagination-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-top:4px;display:flex}.pagination-info{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.pagination-entries{color:var(--text-muted);font-size:13px}.pagination-size-label{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.pagination-size-select{border:1px solid var(--border-color);background:var(--bg-card);height:30px;color:var(--text-secondary);cursor:pointer;border-radius:5px;outline:none;padding:0 6px;font-size:13px}.pagination-size-select:focus{border-color:var(--accent)}.pagination-controls{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.page-btn{border:1px solid var(--border-color);background:var(--bg-card);min-width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:0 8px;font-size:13px;transition:background .12s,border-color .12s,color .12s}.page-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent);color:var(--accent)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.page-btn:disabled{opacity:.35;cursor:not-allowed}.page-ellipsis{width:32px;color:var(--text-muted);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:13px;display:flex}.modal-overlay{z-index:500;background:#00000073;justify-content:center;align-items:center;padding:8px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;width:100%;max-width:480px;box-shadow:0 20px 60px #0003}.modal-sm{max-width:380px}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:18px 20px 16px;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;line-height:1;transition:color .12s,background .12s}.modal-close:hover{color:var(--text-primary);background:var(--bg-page)}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.modal-body p{color:var(--text-secondary);font-size:14px;line-height:1.6}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.form-field{flex-direction:column;gap:6px;display:flex}.form-field label{color:var(--text-secondary);font-size:13px;font-weight:500}.required{color:#ff4d4f;margin-left:2px}.form-field input,.form-field textarea{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);resize:vertical;border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text-faint)}.subcategory-selector{align-items:center;gap:10px;display:flex}.selector-label{color:var(--text-secondary);white-space:nowrap;font-size:13px;font-weight:500}.selector-select{border:1px solid var(--input-border);background:var(--bg-card);height:38px;color:var(--text-primary);cursor:pointer;border-radius:6px;outline:none;min-width:220px;padding:0 10px;font-size:13.5px;transition:border-color .15s}.selector-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.inv-detail-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.inv-detail-back{height:34px;padding:0 14px;font-size:13px}.inv-detail-body{grid-template-columns:1fr 1fr;align-items:start;gap:16px;display:grid}@media (width<=700px){.inv-detail-body{grid-template-columns:1fr}}.inv-detail-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:16px 20px}.inv-detail-card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border-bottom:1px solid var(--border-color);margin:0 0 14px;padding-bottom:10px;font-size:.8rem;font-weight:700}.inv-detail-grid{flex-direction:column;gap:10px;display:flex}.inv-detail-field{justify-content:space-between;align-items:baseline;gap:12px;font-size:13.5px;display:flex}.inv-detail-label{color:var(--text-muted);flex-shrink:0;font-size:12.5px}.inv-detail-value{color:var(--text-primary);text-align:right;font-weight:500}.inv-low-stock-tag{color:#c62828;background:#c628281a;border-radius:10px;margin-left:8px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}[data-theme=dark] .inv-low-stock-tag{color:#ef9a9a;background:#ef9a9a26}.data-table tbody tr.clickable{cursor:pointer}.inv-filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.inv-filter-select{border:1px solid var(--border-color);background:var(--bg-card);height:36px;color:var(--text-secondary);cursor:pointer;border-radius:6px;outline:none;min-width:160px;padding:0 10px;font-size:13px;transition:border-color .15s}.inv-filter-select:focus{border-color:var(--accent)}.inv-filter-select:disabled{opacity:.45;cursor:not-allowed}.inv-search-input{border:1px solid var(--border-color);background:var(--bg-card);height:36px;color:var(--text-primary);border-radius:6px;outline:none;min-width:200px;padding:0 10px;font-family:inherit;font-size:13px;transition:border-color .15s}.inv-search-input:focus{border-color:var(--accent)}.inv-search-input::placeholder{color:var(--text-faint)}.inv-filter-clear{height:36px;padding:0 12px;font-size:12.5px}.csv-modal{max-width:420px}.csv-modal-body{flex-direction:column;gap:14px;display:flex}.csv-modal-hint{color:var(--text-muted);margin:0;font-size:13px}.csv-progress-wrap{align-items:center;gap:10px;margin-top:4px;display:flex}.csv-progress-bar{background:var(--border-color);border-radius:99px;flex:1;height:6px;overflow:hidden}.csv-progress-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .2s}.csv-progress-fill.indeterminate{animation:1.2s ease-in-out infinite csv-indeterminate;width:40%!important}@keyframes csv-indeterminate{0%{transform:translate(-100%)}to{transform:translate(300%)}}.csv-progress-label{color:var(--text-muted);text-align:right;min-width:40px;font-size:12px}.inv-type-badge{letter-spacing:.03em;border-radius:12px;padding:2px 10px;font-size:.75rem;font-weight:600;display:inline-block}.inv-type-badge.product{color:#1565c0;background:#e3f2fd}.inv-type-badge.service{color:#2e7d32;background:#e8f5e9}[data-theme=dark] .inv-type-badge.product{color:#90caf9;background:#0d3263}[data-theme=dark] .inv-type-badge.service{color:#a5d6a7;background:#0d3d1a}.stock-low{color:#c62828;font-weight:600}[data-theme=dark] .stock-low{color:#ef9a9a}.table-card{overflow-x:auto}.modal-lg{flex-direction:column;max-height:92vh;display:flex;width:50vw!important;max-width:50vw!important}.modal-lg .modal-body{flex:1;overflow:hidden auto}.modal-lg *{box-sizing:border-box}@media (width<=768px){.modal-overlay{align-items:flex-end;padding:0!important}.modal-lg{border-radius:16px 16px 0 0!important;width:100vw!important;max-width:100vw!important;max-height:95vh!important}}.inv-form{padding:0 1.5rem 1rem}.inv-form-columns{grid-template-columns:1fr 1fr;align-items:start;gap:0 2rem;display:grid}@media (width<=700px){.inv-form-columns{grid-template-columns:1fr}}.inv-form-section{margin-bottom:1.5rem}.inv-form-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border-bottom:1px solid var(--border-color);margin:0 0 .75rem;padding-bottom:.4rem;font-size:.85rem;font-weight:700}.inv-form-grid{grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr));gap:.75rem 1rem;display:grid}.inv-col-span-2{grid-column:1/-1}.inv-add-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;margin-bottom:16px;overflow:hidden}.inv-add-section-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:12px;padding:10px 16px 8px;display:flex}.inv-add-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);font-size:.8rem;font-weight:700}.inv-add-paste-hint{color:var(--text-faint);font-size:12px}.inv-add-scroll{overflow-x:auto}.inv-add-table{border-collapse:collapse;width:100%;font-size:13px}.inv-add-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg-sidebar);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:6px 8px;font-size:11px;font-weight:600}.inv-add-table td{vertical-align:middle;border-bottom:1px solid var(--border-color);padding:4px}.inv-add-row.inv-add-row-error td{background:#c628280f}.inv-add-row.inv-add-row-error td:first-child{border-left:3px solid #c62828}[data-theme=dark] .inv-add-row.inv-add-row-error td{background:#ef9a9a14}.inv-add-cell-input{border:1px solid var(--border-color);background:var(--bg-main);width:100%;height:32px;color:var(--text-primary);box-sizing:border-box;border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:13px;transition:border-color .15s}.inv-add-cell-input:focus{border-color:var(--accent)}.inv-add-price-input{width:80px}.inv-add-type-select{border:1px solid var(--border-color);background:var(--bg-main);height:32px;color:var(--text-primary);cursor:pointer;box-sizing:border-box;border-radius:4px;outline:none;width:100%;padding:0 6px;font-family:inherit;font-size:13px;transition:border-color .15s}.inv-add-type-select:focus{border-color:var(--accent)}.inv-add-delete-btn{width:28px;height:28px;color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:14px;transition:background .15s,color .15s;display:flex}.inv-add-delete-btn:hover{color:#c62828;background:#c628281a}.inv-add-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.inv-add-row-btn{height:32px;padding:0 12px;font-size:12.5px}.inv-add-footer-actions{gap:8px;display:flex}.inv-add-footer-actions .btn-secondary,.inv-add-footer-actions .btn-primary{height:32px;padding:0 16px;font-size:13px}.inv-bulk-result{color:#2e7d32;background:#e8f5e9;border:1px solid #a5d6a7;border-radius:6px;margin-bottom:12px;padding:8px 14px;font-size:13px}[data-theme=dark] .inv-bulk-result{color:#a5d6a7;background:#a5d6a71a;border-color:#a5d6a74d}.ta-wrap{width:100%;position:relative}.ta-input{border:1px solid var(--border-color);background:var(--bg-main);width:100%;height:32px;color:var(--text-primary);box-sizing:border-box;border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:13px;transition:border-color .15s}.ta-input:focus{border-color:var(--accent)}.ta-input:disabled{opacity:.45;cursor:not-allowed}.ta-dropdown{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;max-height:200px;font-size:13px;overflow-y:auto;box-shadow:0 4px 16px #00000026}.ta-option{cursor:pointer;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;padding:7px 12px;overflow:hidden}.ta-option:hover{background:var(--bg-sidebar)}.ta-option.ta-selected{background:var(--accent);color:#fff}.ta-option.ta-no-match{color:var(--text-faint);cursor:default;font-style:italic}.contact-modal{flex-direction:column;max-height:92vh;display:flex;width:min(860px,98vw)!important;max-width:min(860px,98vw)!important}.contact-modal .modal-body{flex:1;padding:0 1.5rem 1rem;overflow:hidden auto}.contact-modal *{box-sizing:border-box}.contact-form-columns{grid-template-columns:1fr 1fr;align-items:start;gap:0 2rem;display:grid}@media (width<=700px){.contact-form-columns{grid-template-columns:1fr}}.contact-form-section{margin-bottom:1.5rem}.contact-form-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border-bottom:1px solid var(--border-color);margin:0 0 .75rem;padding-bottom:.4rem;font-size:.8rem;font-weight:700}.contact-form-grid{grid-template-columns:1fr 1fr;gap:.75rem 1rem;display:grid}.contact-form-grid .full-width{grid-column:1/-1}@media (width<=500px){.contact-form-grid{grid-template-columns:1fr}}.contact-checkbox-row{flex-wrap:wrap;gap:1.5rem;display:flex}.contact-checkbox-label{color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:13.5px;display:flex}.contact-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}@media (width<=768px){.contact-modal{border-radius:16px 16px 0 0!important;width:100vw!important;max-width:100vw!important;max-height:95vh!important}.modal-overlay{align-items:flex-end;padding:0!important}}.company-body{flex-direction:column;gap:20px;display:flex}.company-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:20px 24px}.company-card-title{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);border-bottom:1px solid var(--border-color);margin:0 0 16px;padding-bottom:10px;font-size:.8rem;font-weight:700}.company-info-grid{grid-template-columns:repeat(3,1fr);gap:12px 24px;display:grid}@media (width<=600px){.company-info-grid{grid-template-columns:1fr}}.company-info-item{flex-direction:column;gap:4px;display:flex}.company-info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:11.5px;font-weight:600}.company-info-value{color:var(--text-primary);font-size:14px;font-weight:500}.company-form-columns{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}@media (width<=700px){.company-form-columns{grid-template-columns:1fr}}.company-form-grid{flex-direction:column;gap:14px;display:flex}.company-form-grid .full-width{grid-column:1/-1}.company-actions{justify-content:flex-end;display:flex}.company-success{color:#2e7d32;background:#2e7d321a;border:1px solid #2e7d3259;border-radius:6px;margin-bottom:4px;padding:10px 14px;font-size:13px}[data-theme=dark] .company-success{color:#a5d6a7;background:#a5d6a71a;border-color:#a5d6a74d}.sales-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.sales-header h2{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.sale-status{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.sale-status.draft{color:#475569;background:#e2e8f0}.sale-status.sent{color:#1d4ed8;background:#dbeafe}.sale-status.accepted{color:#15803d;background:#dcfce7}.sale-status.paid{color:#166534;background:#bbf7d0}.sale-status.rejected{color:#b91c1c;background:#fee2e2}.sale-status.cancelled{color:#94a3b8;background:#f1f5f9}[data-theme=dark] .sale-status.draft{color:#cbd5e1;background:#334155}[data-theme=dark] .sale-status.sent{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .sale-status.accepted{color:#86efac;background:#14532d}[data-theme=dark] .sale-status.paid{color:#4ade80;background:#14532d}[data-theme=dark] .sale-status.rejected{color:#fca5a5;background:#450a0a}[data-theme=dark] .sale-status.cancelled{color:#64748b;background:#1e293b}.sale-modal{width:min(900px,96vw)!important;max-width:min(900px,96vw)!important}.sale-modal .modal-body{max-height:78vh;overflow:hidden auto}.sale-modal *{box-sizing:border-box}.sale-form-top{grid-template-columns:1fr 1fr;gap:.75rem 1.25rem;margin-bottom:1rem;display:grid}.sale-form-top .form-field{margin-bottom:0}.sale-modal .form-field select{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s}.sale-modal .form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.form-label-standalone{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.sale-items-section{margin-top:1rem}.sale-items-section h4{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.875rem;font-weight:600}.sale-items-table{border-collapse:collapse;width:100%;margin-bottom:.5rem;font-size:.82rem}.sale-items-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;padding:6px 8px;font-size:.75rem;font-weight:600}.sale-items-table td{vertical-align:middle;padding:4px}.sale-items-table td input,.sale-items-table td select{border:1px solid var(--border);background:var(--bg-input,var(--bg-card));width:100%;color:var(--text-primary);border-radius:6px;padding:5px 7px;font-size:.8rem}.sale-items-table td input:focus,.sale-items-table td select:focus{border-color:var(--accent);outline:none}.sale-item-remove-btn{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-size:1rem;line-height:1}.sale-item-remove-btn:hover{background:#fee2e2}[data-theme=dark] .sale-item-remove-btn:hover{background:#450a0a}.sale-add-item-btn{border:1px dashed var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;margin-top:.25rem;padding:5px 14px;font-size:.82rem;transition:background .15s}.sale-add-item-btn:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.sale-totals{border-top:1px solid var(--border);flex-direction:column;align-items:flex-end;gap:.3rem;margin-top:.75rem;padding-top:.75rem;display:flex}.sale-totals-row{align-items:center;gap:1rem;min-width:280px;display:flex}.sale-totals-row span:first-child{text-align:right;color:var(--text-secondary);flex:1;font-size:.85rem}.sale-totals-row span:last-child{text-align:right;width:110px;color:var(--text-primary);font-size:.85rem}.sale-totals-row.grand{font-size:1rem;font-weight:700}.sale-totals-row.grand span{color:var(--text-primary);font-size:1rem}.sale-notes{margin-top:1rem}.sale-notes textarea{border:1px solid var(--border);background:var(--bg-input,var(--bg-card));width:100%;color:var(--text-primary);resize:vertical;border-radius:6px;min-height:64px;padding:8px;font-size:.85rem}.sale-notes textarea:focus{border-color:var(--accent);outline:none}.sale-detail-back{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:1rem;padding:0;font-size:.9rem;display:inline-flex}.sale-detail-back:hover{text-decoration:underline}.sale-detail-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.sale-detail-number{color:var(--text-primary);font-size:1.4rem;font-weight:700}.sale-items-view-table{border-collapse:collapse;width:100%;margin-top:.5rem;font-size:.85rem}.sale-items-view-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--border);padding:8px 10px;font-size:.75rem;font-weight:600}.sale-items-view-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:8px 10px}.sale-items-view-table tr:last-child td{border-bottom:none}@media (width<=768px){.sale-modal{border-radius:16px 16px 0 0;max-height:95vh;width:100vw!important;max-width:100vw!important}.sale-form-top{grid-template-columns:1fr}.sale-items-table{font-size:.75rem}}.project-status{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.project-status.planning{color:#0369a1;background:#e0f2fe}.project-status.active{color:#15803d;background:#dcfce7}.project-status.on_hold{color:#854d0e;background:#fef9c3}.project-status.completed{color:#166534;background:#bbf7d0}.project-status.cancelled{color:#94a3b8;background:#f1f5f9}[data-theme=dark] .project-status.planning{color:#7dd3fc;background:#0c4a6e}[data-theme=dark] .project-status.active{color:#86efac;background:#14532d}[data-theme=dark] .project-status.on_hold{color:#fde68a;background:#422006}[data-theme=dark] .project-status.completed{color:#4ade80;background:#14532d}[data-theme=dark] .project-status.cancelled{color:#64748b;background:#1e293b}.task-status{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.task-status.todo{color:#475569;background:#e2e8f0}.task-status.in_progress{color:#1d4ed8;background:#dbeafe}.task-status.review{color:#854d0e;background:#fef9c3}.task-status.done{color:#166534;background:#bbf7d0}[data-theme=dark] .task-status.todo{color:#cbd5e1;background:#334155}[data-theme=dark] .task-status.in_progress{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .task-status.review{color:#fde68a;background:#422006}[data-theme=dark] .task-status.done{color:#4ade80;background:#14532d}.task-priority{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.task-priority.low{color:#64748b;background:#f1f5f9}.task-priority.medium{color:#0369a1;background:#e0f2fe}.task-priority.high{color:#854d0e;background:#fef9c3}.task-priority.urgent{color:#b91c1c;background:#fee2e2}[data-theme=dark] .task-priority.low{color:#94a3b8;background:#1e293b}[data-theme=dark] .task-priority.medium{color:#7dd3fc;background:#0c4a6e}[data-theme=dark] .task-priority.high{color:#fde68a;background:#422006}[data-theme=dark] .task-priority.urgent{color:#fca5a5;background:#450a0a}.project-modal{width:min(560px,96vw)!important;max-width:min(560px,96vw)!important}.project-modal .modal-body{max-height:75vh;overflow-y:auto}.project-form-grid{grid-template-columns:1fr 1fr;gap:.75rem 1.25rem;margin-bottom:.75rem;display:grid}.project-form-grid .form-field{margin-bottom:0}.project-form-grid .form-field.full-width{grid-column:1/-1}.project-modal .form-field select{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s}.project-modal .form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.task-modal{width:min(480px,96vw)!important;max-width:min(480px,96vw)!important}.task-modal .modal-body{max-height:75vh;overflow-y:auto}.task-modal .form-field select{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s}.task-modal .form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.project-detail-back{color:var(--accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:1rem;padding:0;font-size:.9rem;display:inline-flex}.project-detail-back:hover{text-decoration:underline}.project-detail-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.project-detail-number{color:var(--text-primary);font-size:1.4rem;font-weight:700}.project-detail-name{color:var(--text-secondary);font-size:1rem}.kanban-board{grid-template-columns:repeat(4,1fr);align-items:start;gap:1rem;display:grid}.kanban-column{background:var(--bg-page);border-radius:10px;min-height:180px;padding:.75rem}.kanban-column-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.kanban-column-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:.78rem;font-weight:700}.kanban-column-count{background:var(--border);color:var(--text-secondary);border-radius:99px;padding:1px 8px;font-size:.72rem;font-weight:700}.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;padding:.65rem .75rem;transition:box-shadow .15s}.kanban-card:hover{box-shadow:0 2px 10px #00000014}[data-theme=dark] .kanban-card:hover{box-shadow:0 2px 10px #0000004d}.kanban-card-title{color:var(--text-primary);margin-bottom:.4rem;font-size:.875rem;font-weight:500;line-height:1.35}.kanban-card-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.5rem;font-size:.78rem;line-height:1.4;display:-webkit-box;overflow:hidden}.kanban-card-meta{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.kanban-card-due{color:var(--text-secondary);font-size:.72rem}.kanban-card-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.kanban-card:hover .kanban-card-actions{opacity:1}.kanban-add-btn{border:1px dashed var(--border);width:100%;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:8px;margin-top:.25rem;padding:6px;font-family:inherit;font-size:.8rem;transition:border-color .15s,color .15s}.kanban-add-btn:hover{border-color:var(--accent);color:var(--accent)}@media (width<=900px){.kanban-board{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.project-form-grid,.kanban-board{grid-template-columns:1fr}.project-modal,.task-modal{border-radius:16px 16px 0 0;max-height:95vh;width:100vw!important;max-width:100vw!important}}.emp-status{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.emp-status.active{color:#15803d;background:#dcfce7}.emp-status.inactive{color:#94a3b8;background:#f1f5f9}.emp-status.on_leave{color:#854d0e;background:#fef9c3}.emp-status.terminated{color:#b91c1c;background:#fee2e2}[data-theme=dark] .emp-status.active{color:#86efac;background:#14532d}[data-theme=dark] .emp-status.inactive{color:#64748b;background:#1e293b}[data-theme=dark] .emp-status.on_leave{color:#fde68a;background:#422006}[data-theme=dark] .emp-status.terminated{color:#fca5a5;background:#450a0a}.emp-type{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.emp-type.full_time{color:#1d4ed8;background:#dbeafe}.emp-type.part_time{color:#0369a1;background:#e0f2fe}.emp-type.contract{color:#7c3aed;background:#faf5ff}[data-theme=dark] .emp-type.full_time{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .emp-type.part_time{color:#7dd3fc;background:#0c4a6e}[data-theme=dark] .emp-type.contract{color:#d8b4fe;background:#3b0764}.payroll-status{text-transform:uppercase;letter-spacing:.04em;border-radius:99px;padding:2px 10px;font-size:.72rem;font-weight:600;display:inline-block}.payroll-status.draft{color:#475569;background:#f1f5f9}.payroll-status.processed{color:#854d0e;background:#fef9c3}.payroll-status.paid{color:#15803d;background:#dcfce7}[data-theme=dark] .payroll-status.draft{color:#cbd5e1;background:#334155}[data-theme=dark] .payroll-status.processed{color:#fde68a;background:#422006}[data-theme=dark] .payroll-status.paid{color:#86efac;background:#14532d}.hr-modal{width:min(620px,96vw)!important;max-width:min(620px,96vw)!important}.hr-modal .modal-body{max-height:75vh;overflow-y:auto}.hr-form-grid{grid-template-columns:1fr 1fr;gap:.75rem 1.25rem;margin-bottom:.75rem;display:grid}.hr-form-grid .form-field{margin-bottom:0}.hr-form-grid .form-field.full-width{grid-column:1/-1}.hr-modal .form-field select{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s}.hr-modal .form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.payroll-items-section{margin-top:1rem}.payroll-items-section h4{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:.6rem;font-size:.82rem;font-weight:600}.payroll-items-table{border-collapse:collapse;width:100%;font-size:.82rem}.payroll-items-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border);padding:6px 8px;font-size:.72rem;font-weight:600}.payroll-items-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:5px 8px}.payroll-items-table input,.payroll-items-table select{border:1px solid var(--input-border);width:100%;color:var(--text-primary);background:var(--bg-card);border-radius:5px;outline:none;padding:4px 8px;font-family:inherit;font-size:.82rem}.payroll-items-table input:focus,.payroll-items-table select:focus{border-color:var(--accent)}.payroll-items-table .net-pay-cell{color:var(--text-primary);font-weight:500}.add-item-btn{border:1px dashed var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;margin-top:.5rem;padding:5px 12px;font-family:inherit;font-size:.8rem;transition:border-color .15s,color .15s}.add-item-btn:hover{border-color:var(--accent);color:var(--accent)}.remove-item-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:.9rem}@media (width<=768px){.hr-form-grid{grid-template-columns:1fr}.hr-modal{border-radius:16px 16px 0 0;max-height:95vh;width:100vw!important;max-width:100vw!important}}.accounting-report{max-width:960px}.accounting-balance-columns{grid-template-columns:1fr 1fr;align-items:start;gap:32px;display:grid}.accounting-balance-col{min-width:0}@media (width<=640px){.accounting-balance-columns{grid-template-columns:1fr;gap:0}}.accounting-report-controls{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:24px;display:flex}.accounting-report-section{margin-bottom:28px}.accounting-report-section h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted,#6b7280);border-bottom:1px solid var(--border,#e5e7eb);margin:0 0 8px;padding-bottom:6px;font-size:14px;font-weight:600}.accounting-report-table{border-collapse:collapse;border:1px solid var(--border,#e5e7eb);width:100%}.accounting-report-table td{border:1px solid var(--border-light,#e5e7eb);padding:8px 12px;font-size:14px}.accounting-report-table td:last-child{text-align:right;font-variant-numeric:tabular-nums}.accounting-report-total{font-weight:600}.accounting-report-total td{border-top:2px solid var(--border,#d1d5db)}.accounting-net-profit{border-radius:6px;justify-content:space-between;align-items:center;margin-top:12px;padding:12px 16px;font-size:15px;font-weight:600;display:flex}.accounting-net-profit.positive{background:var(--success-bg,#f0fdf4);color:var(--success,#16a34a)}.accounting-net-profit.negative{background:var(--danger-bg,#fef2f2);color:var(--danger,#dc2626)}.accounting-balance-check{background:var(--info-bg,#eff6ff);color:var(--info,#1d4ed8);border-radius:6px;margin-top:16px;padding:10px 16px;font-size:13px}.accounting-trial-balance-table thead th{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted,#6b7280);border-bottom:2px solid var(--border,#e5e7eb);text-align:left;padding:8px 12px;font-size:12px;font-weight:600}.accounting-trial-balance-table thead th.accounting-amount-col,.accounting-trial-balance-table td.accounting-amount-col{text-align:right;font-variant-numeric:tabular-nums}.ledger-lines-table{border-collapse:collapse;width:calc(100% - 60px);margin:10px 20px 10px 40px;font-size:13px}.ledger-lines-table th,.ledger-lines-table td{text-align:left;border-bottom:1px solid var(--border-light,#f3f4f6);padding:6px 10px}.ledger-lines-table th{color:var(--text-muted,#6b7280);font-size:12px;font-weight:600}.ledger-lines-table td:nth-child(2),.ledger-lines-table td:nth-child(3),.ledger-lines-table th:nth-child(2),.ledger-lines-table th:nth-child(3){text-align:right}.ledger-entry-detail{background:var(--surface-2,#f9fafb);border-radius:8px;margin-top:8px;padding:12px 16px}.add-line-btn{border:1px dashed var(--border,#d1d5db);color:var(--text-muted,#6b7280);cursor:pointer;background:0 0;border-radius:6px;width:100%;margin-top:8px;padding:6px 12px;font-size:13px}.add-line-btn:hover{background:var(--surface-2,#f9fafb);color:var(--text,#111827)}.remove-line-btn{color:var(--danger,#dc2626);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.ledger-form-grid{grid-template-columns:1fr 100px 100px 32px;align-items:center;gap:8px;margin-bottom:4px;display:grid}.ledger-form-grid-header{color:var(--text-muted,#6b7280);grid-template-columns:1fr 100px 100px 32px;gap:8px;margin-bottom:4px;font-size:12px;font-weight:600;display:grid}.debit-credit-validation{border-radius:4px;margin-top:8px;padding:6px 10px;font-size:12px}.debit-credit-validation.ok{background:var(--success-bg,#f0fdf4);color:var(--success,#16a34a)}.debit-credit-validation.mismatch{background:var(--danger-bg,#fef2f2);color:var(--danger,#dc2626)}.acc-type-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.acc-type-badge.ASSET{color:#1e40af;background:#dbeafe}.acc-type-badge.LIABILITY{color:#9d174d;background:#fce7f3}.acc-type-badge.EQUITY{color:#5b21b6;background:#ede9fe}.acc-type-badge.INCOME{color:#166534;background:#dcfce7}.acc-type-badge.EXPENSE{color:#991b1b;background:#fee2e2}[data-theme=dark] .acc-type-badge.ASSET{color:#93c5fd;background:#1e3a5f}[data-theme=dark] .acc-type-badge.LIABILITY{color:#f9a8d4;background:#4a1942}[data-theme=dark] .acc-type-badge.EQUITY{color:#c4b5fd;background:#2e1a5e}[data-theme=dark] .acc-type-badge.INCOME{color:#86efac;background:#14532d}[data-theme=dark] .acc-type-badge.EXPENSE{color:#fca5a5;background:#450a0a}.accounting-modal{max-width:520px}.accounting-modal-lg{flex-direction:column;width:680px;max-width:96vw;max-height:92vh;display:flex}.accounting-modal-lg .modal-body{flex:1;overflow-y:auto}.form-field select{border:1px solid var(--input-border);color:var(--text-primary);background:var(--bg-card);cursor:pointer;border-radius:6px;outline:none;width:100%;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4d9fff26}.acc-form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=500px){.acc-form-grid{grid-template-columns:1fr}}.journal-lines-section{border:1px solid var(--border-color);border-radius:6px;flex-direction:column;gap:0;display:flex;overflow:hidden}.journal-lines-header{background:var(--bg-page);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border-color);grid-template-columns:1fr 110px 110px 32px;gap:8px;padding:8px 10px;font-size:11px;font-weight:600;display:grid}.journal-lines-row{border-bottom:1px solid var(--border-color);grid-template-columns:1fr 110px 110px 32px;align-items:center;gap:8px;padding:6px 10px;display:grid}.journal-lines-row:last-of-type{border-bottom:none}.journal-lines-row select{border:1px solid var(--border-color);background:var(--bg-card);height:34px;color:var(--text-primary);cursor:pointer;border-radius:5px;outline:none;width:100%;padding:0 8px;font-family:inherit;font-size:13px;transition:border-color .15s}.journal-lines-row select:focus{border-color:var(--accent)}.journal-lines-row input[type=number]{border:1px solid var(--border-color);background:var(--bg-card);height:34px;color:var(--text-primary);border-radius:5px;outline:none;width:100%;padding:0 8px;font-family:inherit;font-size:13px;transition:border-color .15s}.journal-lines-row input[type=number]:focus{border-color:var(--accent)}.add-item-btn{color:var(--accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:8px 10px;font-size:13px;font-weight:500;transition:background .12s}.add-item-btn:hover{background:var(--bg-hover)}.remove-item-btn{width:28px;height:28px;color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;font-size:14px;transition:background .15s,color .15s;display:flex}.remove-item-btn:hover{color:#c62828;background:#c628281a}.balance-check{border-radius:5px;margin:4px 10px 6px;padding:7px 12px;font-size:12.5px;font-weight:500}.balance-check.balanced{background:var(--success-bg,#f0fdf4);color:var(--success,#16a34a)}.balance-check.unbalanced{background:var(--danger-bg,#fef2f2);color:var(--danger,#dc2626)}.ledger-lines-row>td{background:var(--bg-page);border-bottom:1px solid var(--border-color);padding:0}.al-opening-row td{color:var(--text-muted);font-style:italic}.al-closing-row td{border-top:2px solid var(--border-color);padding-top:10px}.al-debit-col{color:var(--danger,#dc2626);font-weight:500}.al-credit-col{color:var(--success,#16a34a);font-weight:500}[data-theme=dark] .al-debit-col{color:#fca5a5}[data-theme=dark] .al-credit-col{color:#86efac}.acc-name-link{color:var(--accent);cursor:pointer;text-decoration:none}.acc-name-link:hover{text-decoration:underline}.se-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;margin-bottom:16px;overflow:hidden}.se-panel-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-right:16px;display:flex}.se-panel-tabs{display:flex}.se-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 28px;font-size:13.5px;font-weight:500;transition:background .15s,color .15s}.se-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.se-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.se-panel-body{flex-direction:column;gap:14px;padding:20px;display:flex}.se-panel-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.se-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}@media (width<=540px){.se-grid{grid-template-columns:1fr}}.se-amount-field{max-width:220px}.table-card .data-table,.table-card .data-table th,.table-card .data-table td{border:1px solid var(--border-color)}.table-card .data-table tbody tr:last-child td{border-bottom:1px solid var(--border-color)}.se-income-col{color:var(--success,#16a34a);font-weight:500}.se-expense-col{color:var(--danger,#dc2626);font-weight:500}[data-theme=dark] .se-income-col{color:#86efac}[data-theme=dark] .se-expense-col{color:#fca5a5}.se-tfoot-row td{border-top:2px solid var(--border-color);padding-top:10px;font-weight:600}.se-net{padding:4px 0;font-size:14px;font-weight:700;display:inline-block}.se-net-positive{color:var(--success,#16a34a)}.se-net-negative{color:var(--danger,#dc2626)}[data-theme=dark] .se-net-positive{color:#86efac}[data-theme=dark] .se-net-negative{color:#fca5a5}
