*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:#f0f2f5;color:#1a1a1a}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh}.login-card{background:#fff;padding:2.5rem 2rem;border-radius:12px;box-shadow:0 4px 24px #00000014;width:100%;max-width:380px}.login-card h1{font-size:1.5rem;margin-bottom:.25rem}.login-card p.subtitle{color:#666;margin-bottom:1.5rem;font-size:.9rem}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.3rem}.form-group input,.form-group select{width:100%;padding:.6rem .75rem;border:1px solid #d0d5dd;border-radius:8px;font-size:.95rem;background-color:#fff;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.btn{display:inline-block;width:100%;padding:.65rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;margin-top:.5rem}.btn-primary{background:#2563eb;color:#fff}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{background:#93b4f5;cursor:not-allowed}.btn-sm{width:auto;padding:.3rem .5rem;font-size:.8rem;margin-top:0}.error-msg{color:#dc2626;font-size:.85rem;margin-top:.75rem}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;overflow-y:auto}.sidebar{width:220px;flex-shrink:0;background:#1e2330;color:#c9cdd8;display:flex;flex-direction:column;min-height:100vh;position:sticky;top:0;height:100vh}.sidebar-logo{padding:1.25rem 1.25rem 1rem;font-size:1rem;font-weight:700;color:#fff;border-bottom:1px solid rgba(255,255,255,.07);letter-spacing:.02em;display:flex;align-items:center;gap:.6rem}.sidebar-logo-img{width:32px;height:32px;object-fit:contain;border-radius:4px;flex-shrink:0}.sidebar-nav{padding:.75rem 0;flex:1}.sidebar-category{padding:.3rem 1.25rem;margin-top:.25rem}.sidebar-category-label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#6b7280;padding:.5rem 0 .25rem}.sidebar-link{display:block;padding:.45rem .75rem;border-radius:6px;font-size:.875rem;color:#c9cdd8;text-decoration:none;transition:background .15s,color .15s}.sidebar-link:hover{background:#ffffff12;color:#fff}.sidebar-link.active{background:#2563eb;color:#fff;font-weight:600}.sidebar-toggle-btn{display:block;width:calc(100% - 1.2rem);margin:.75rem .6rem 0;padding:.45rem .6rem;font-size:.78rem;font-weight:600;color:#555;background:#f3f4f6;border:1px solid #d0d5dd;border-radius:6px;cursor:pointer;text-align:center;transition:background .15s}.sidebar-toggle-btn:hover{background:#e5e7eb;color:#2563eb}.page-content{max-width:80%;margin:0 auto;padding:2rem 1rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.6rem}.top-bar{position:fixed;top:1rem;right:1.5rem;z-index:900;display:flex;align-items:center;gap:.75rem}.top-bar-user{font-size:.9rem;color:#555;font-weight:500}.btn-logout{background:#dc2626;color:#fff;border:none;border-radius:8px;padding:.4rem 1rem;font-size:.85rem;cursor:pointer;font-weight:600}.btn-logout:hover{background:#b91c1c}table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:visible;box-shadow:0 2px 12px #0000000f}th,td{text-align:left;padding:.75rem 1rem;white-space:nowrap}td{overflow:hidden;text-overflow:ellipsis}th{background:#f9fafb;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;color:#555}tr:not(:last-child) td{border-bottom:1px solid #f0f0f0}.col-header{position:relative;padding:0!important;-webkit-user-select:none;user-select:none}.col-resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;z-index:10}.col-resize-handle:hover{background:#2563eb4d}.col-header-btn{display:flex;align-items:center;justify-content:space-between;gap:.35rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;font:inherit;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#555;text-align:left}.col-header-btn:hover{background:#eef1f5}.col-header-btn.col-filtered{color:#2563eb}.col-header-icon{font-size:.7rem;flex-shrink:0}.col-filter-popup{position:absolute;top:100%;left:0;z-index:100;min-width:180px;padding:.6rem;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 6px 20px #00000026;display:flex;flex-direction:column;gap:.4rem}.col-filter-label{display:flex;flex-direction:column;font-size:.72rem;font-weight:500;color:#888;text-transform:none;letter-spacing:0;gap:.2rem}.col-filter-input{width:100%;padding:.35rem .45rem;font-size:.82rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;box-sizing:border-box}.col-filter-input:focus{outline:none;border-color:#4f8cff;box-shadow:0 0 0 2px #4f8cff2e}.col-filter-clear{margin-top:.15rem;padding:.3rem 0;font-size:.75rem;border:none;border-radius:4px;background:none;color:#888;cursor:pointer;text-align:center;text-transform:none;letter-spacing:0}.col-filter-clear:hover{color:#d32f2f;background:#fff0f0}.col-filter-sort{display:flex;flex-direction:column;gap:.25rem}.col-sort-btn{padding:.35rem .5rem;font-size:.8rem;border:1px solid #e5e7eb;border-radius:4px;background:#fff;color:#555;cursor:pointer;text-align:left;text-transform:none;letter-spacing:0}.col-sort-btn:hover{background:#f5f7fa}.col-sort-btn.active{background:#dbeafe;color:#1d4ed8;border-color:#93b4f5;font-weight:600}.col-filter-divider{border:none;border-top:1px solid #e5e7eb;margin:.2rem 0}.searchable-select{display:flex;flex-direction:column;gap:.3rem}.searchable-list{max-height:180px;overflow-y:auto;border:1px solid #e5e7eb;border-radius:4px;background:#fff}.searchable-item{display:flex;align-items:center;padding:.4rem .55rem;margin:1px 2px;border-radius:3px;font-size:.82rem;cursor:pointer;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:none;letter-spacing:0}.searchable-item:hover{background:#eef3ff}.searchable-item.selected{background:#dbeafe;font-weight:600;color:#1d4ed8}.searchable-empty{padding:.5rem;font-size:.78rem;color:#999;text-align:center;text-transform:none;letter-spacing:0}.searchable-current{font-size:.72rem;color:#888;text-transform:none;letter-spacing:0}.status-badge{display:inline-block;padding:.15rem .6rem;border-radius:999px;font-size:.78rem;font-weight:600}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.inactive{background:#fee2e2;color:#991b1b}.status-badge.pending{background:#fef9c3;color:#854d0e}.status-badge.approved{background:#dcfce7;color:#166534}.status-badge.paid{background:#dbeafe;color:#1e40af}.status-badge.rejected{background:#fee2e2;color:#991b1b}.icon-btn{background:none;border:none;cursor:pointer;padding:.35rem;border-radius:6px;color:#64748b;transition:background .15s,color .15s;display:inline-flex;align-items:center;justify-content:center}.icon-btn:hover{background:#e2e8f0;color:#1e293b}.loading{text-align:center;padding:3rem;color:#888}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{position:relative;background:#fff;border-radius:12px;padding:2rem;width:100%;max-width:480px;box-shadow:0 8px 32px #0000002e;max-height:90vh;overflow-y:auto}.detail-card{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 12px #0000000f;margin-bottom:1.5rem}.burger-menu{position:absolute;top:1rem;right:1rem;z-index:10}.burger-btn{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:36px;height:36px;background:#f3f4f6;border:1px solid #d0d5dd;border-radius:8px;cursor:pointer;padding:0;transition:background .15s}.burger-btn:hover{background:#e5e7eb}.burger-btn span{display:block;width:18px;height:2px;background:#374151;border-radius:1px}.burger-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:170px;background:#fff;border:1px solid #d0d5dd;border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:.35rem 0;display:flex;flex-direction:column}.burger-dropdown a{display:block;padding:.55rem 1rem;font-size:.9rem;font-weight:500;color:#1a1a1a;text-decoration:none;transition:background .12s}.burger-dropdown a:hover{background:#f0f4ff;color:#2563eb}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.detail-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:#888;margin-bottom:.2rem}.detail-value{font-size:.95rem;font-weight:600}.print-report-section{margin-top:2rem}.print-report-section h2{margin-bottom:.75rem}.project-search{position:relative;width:100%;margin-bottom:1.5rem}.project-search-input{width:100%;padding:.55rem .85rem;border:1px solid #d0d5dd;border-radius:8px;font-size:.9rem;background:#fff}.project-search-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb26}.project-search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #d0d5dd;border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:20;max-height:280px;overflow-y:auto;display:flex;flex-direction:column}.project-search-item{display:flex;gap:.6rem;align-items:center;padding:.55rem .85rem;border:none;background:none;width:100%;text-align:left;font-size:.88rem;cursor:pointer;transition:background .12s}.project-search-item:hover{background:#f0f4ff;color:#2563eb}.project-search-item strong{min-width:60px}.project-search-item span{color:#555}.project-search-item:hover span{color:#2563eb}.dash-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1rem;margin-bottom:2rem}.dash-card{background:#fff;border-radius:10px;padding:1.25rem 1.5rem;box-shadow:0 2px 12px #0000000f;cursor:pointer;transition:box-shadow .15s,transform .15s;display:flex;flex-direction:column;gap:.25rem}.dash-card:hover{box-shadow:0 4px 20px #2563eb1f;transform:translateY(-2px)}.dash-card-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:#888;font-weight:600}.dash-card-value{font-size:1.75rem;font-weight:700;color:#1a1a1a;line-height:1.1}.dash-card-sub{font-size:.82rem;color:#666}.dash-tables{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.dash-section h2{font-size:1rem;margin-bottom:.75rem;color:#344054}@media(max-width:700px){.dash-tables{grid-template-columns:1fr}}.pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.5rem 0}.pagination-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.45rem 1rem;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#344054;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#2563eb;color:#2563eb}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:.85rem;color:#555;font-weight:500;min-width:8rem;text-align:center}@media print{.sidebar,.top-bar,.btn-logout,.btn-primary,.page-header a{display:none!important}.app-main{margin-left:0!important;padding:0!important}.page-content{max-width:100%!important;padding:0!important}table{box-shadow:none;font-size:.8rem}}
