*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #00AEEF;--blue-dark: #0090C5;--black: #1a1a1a;--gray-dark: #4a4a4a;--gray: #888;--gray-light: #d4d4d4;--gray-bg: #f5f5f5;--white: #ffffff;--red: #e53e3e;--green: #38a169;--radius: 6px;--shadow: 0 1px 4px rgba(0,0,0,.1)}body{font-family:Inter,sans-serif;font-size:14px;color:var(--black);background:var(--gray-bg);min-height:100vh}.app-header{background:var(--white);border-bottom:2px solid var(--blue);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.app-header img{height:36px}.app-header .header-right{display:flex;align-items:center;gap:16px}.app-header .user-info{font-size:13px;color:var(--gray-dark)}.app-header .logout-btn{background:none;border:1px solid var(--gray-light);border-radius:var(--radius);padding:5px 12px;cursor:pointer;font-size:13px;color:var(--gray-dark)}.app-header .logout-btn:hover{border-color:var(--blue);color:var(--blue)}.main-content{padding:24px;max-width:1400px;margin:0 auto}.tabs{display:flex;gap:2px;border-bottom:2px solid var(--gray-light);margin-bottom:24px}.tab-btn{padding:10px 20px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--gray);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap}.tab-btn:hover{color:var(--blue)}.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:500}.table-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 220px)}.data-table{width:100%;border-collapse:collapse;background:var(--white)}.data-table th{background:var(--black);color:var(--white);padding:9px 12px;text-align:left;font-weight:500;font-size:13px;white-space:nowrap;position:sticky;top:0;z-index:1}.data-table td{padding:8px 12px;border-bottom:1px solid var(--gray-light);font-size:13px}.data-table tr:hover td{background:#f0f9fe}.data-table tr.inactive td{background:var(--gray-bg);color:var(--gray)}.data-table tr.inactive:hover td{background:#ebebeb}.data-table tr.subrow td{background:#fafafa;font-size:12px;color:var(--gray-dark)}.data-table tr.subrow td:first-child{padding-left:32px}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:var(--radius);border:none;cursor:pointer;font-size:13px;font-weight:500;transition:opacity .15s}.btn:hover{opacity:.85}.btn-primary{background:var(--blue);color:var(--white)}.btn-danger{background:var(--red);color:var(--white)}.btn-outline{background:var(--white);color:var(--black);border:1px solid var(--gray-light)}.btn-outline:hover{border-color:var(--blue);color:var(--blue)}.btn-sm{padding:4px 10px;font-size:12px}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:12px;color:var(--gray-dark);font-weight:500}.form-group input,.form-group select,.form-group textarea{padding:8px 10px;border:1px solid var(--gray-light);border-radius:var(--radius);font-size:13px;font-family:inherit;background:var(--white)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--blue)}.form-group input:disabled,.form-group select:disabled{background:var(--gray-bg);color:var(--gray)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-grid.cols-1{grid-template-columns:1fr}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:var(--white);border-radius:10px;padding:28px;min-width:360px;max-width:520px;width:90%;box-shadow:0 8px 32px #0000002e}.modal h2{font-size:16px;margin-bottom:20px}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500}.badge-open{background:#e6f7ff;color:var(--blue-dark)}.badge-closed{background:var(--gray-bg);color:var(--gray)}.badge-active{background:#e6ffed;color:var(--green)}.badge-fired{background:var(--gray-bg);color:var(--gray)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-bg)}.login-card{background:var(--white);border-radius:12px;padding:40px;width:360px;box-shadow:0 4px 24px #0000001a;display:flex;flex-direction:column;align-items:center;gap:24px}.login-card img{height:48px}.login-card h1{font-size:18px;color:var(--black);font-weight:600;text-align:center}.login-card form{width:100%;display:flex;flex-direction:column;gap:14px}.login-card .error{color:var(--red);font-size:12px;text-align:center}.employee-wrap{max-width:540px;margin:32px auto;background:var(--white);border-radius:12px;padding:28px;box-shadow:var(--shadow)}.employee-wrap h2{font-size:16px;margin-bottom:20px;color:var(--black)}.hours-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--gray-light)}.hours-row:last-of-type{border-bottom:none}.hours-row .project-name{flex:1;font-size:13px}.hours-row .project-num{width:80px;font-size:12px;color:var(--gray)}.hours-row input[type=number]{width:64px;padding:6px 8px;border:1px solid var(--gray-light);border-radius:var(--radius);text-align:center;font-size:14px}.hours-total{display:flex;justify-content:space-between;padding:12px 0 0;font-weight:600;font-size:15px}.hours-total.over{color:var(--red)}.submitted-view{padding:8px 0;color:var(--gray-dark);font-size:13px}.confirm-group{margin-bottom:2px}.confirm-main-row td{font-weight:500;background:#f0f9fe!important}.confirm-actions{display:flex;gap:6px}.report-filters{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}.report-filters label{font-size:12px;color:var(--gray-dark)}.report-filters select,.report-filters input[type=date]{padding:6px 10px;border:1px solid var(--gray-light);border-radius:var(--radius);font-size:13px}.page-title{font-size:18px;font-weight:600;margin-bottom:16px}.empty-msg{text-align:center;padding:40px;color:var(--gray);font-size:14px}.alert-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:var(--radius);padding:10px 16px;margin-bottom:16px;font-size:13px;color:#856404}.expand-btn{background:none;border:none;cursor:pointer;color:var(--blue);font-size:14px}input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--blue)}@media (max-width: 600px){.main-content{padding:12px}.form-grid{grid-template-columns:1fr}.tabs{overflow-x:auto}}
