:root{--bg:#f1f5f9;--panel:#ffffff;--ink:#1e293b;--muted:#64748b;--line:#d8e0ea;--brand:#ea580c;--navy:#1e293b;--danger:#b42318;--warn:#b45309}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;font-size:16px;max-width:100%}input,select,textarea{width:100%;min-width:0;min-height:44px;border:1px solid var(--line);border-radius:8px;padding:10px 12px;background:#fff}textarea{min-height:72px;resize:vertical}.button,button{min-height:42px;border:1px solid var(--line);border-radius:8px;padding:10px 14px;background:#fff;cursor:pointer}.primary{border-color:var(--brand);background:var(--brand);color:#fff;box-shadow:0 2px 8px rgba(234,88,12,.25)}.danger-button{background:#fee4e2;color:var(--danger)}.ghost{background:transparent}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--navy);border-bottom:none}.topbar.role-admin{background:var(--brand)}.topbar.role-manager,.topbar.role-worker{background:#115e59}.brand{font-weight:800;font-size:20px;white-space:nowrap;color:#fff}.topbar .role{font-size:14px;padding:8px 12px;background:rgba(255,255,255,.2);color:#fff}.menu-button,.menu-toggle{display:none}nav{display:flex;flex:1 1;gap:6px;overflow:auto}nav a{padding:8px 10px;border-radius:8px;color:#cbd5e1;white-space:nowrap}nav a.active{background:rgba(255,255,255,.24);color:#fff;font-weight:700}.badge,.role{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;border-radius:999px;padding:4px 8px;font-size:12px;font-weight:700;white-space:nowrap}.admin{background:#fee4e2;color:var(--danger)}.manager{background:#dcfae6;color:#067647}.muted,.worker{background:#eef2f6;color:#475467}.warn{background:#fef0c7;color:#93370d}.container{max-width:1180px;margin:0 auto;padding:18px}.panel{margin-bottom:16px;padding:16px;background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:0 1px 3px rgba(16,24,40,.04)}h1,h2,h3{margin:0 0 12px;line-height:1.2}h1{font-size:26px}h2{font-size:18px}p{line-height:1.7}.hint{margin:0 0 12px;color:var(--muted)}.steps{margin:0;padding-left:22px;line-height:1.8}.alert{border-left:4px solid var(--warn);background:#fffbeb;padding:12px;border-radius:8px}.alert.success{border-left-color:#15803d;background:#ecfdf3}.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;gap:12px;margin-bottom:16px}.stats div,.tile{background:#fff;border:1px solid var(--line);border-radius:10px;padding:16px}.tile{border-left:4px solid var(--brand);border-radius:0 10px 10px 0}.tile h2{margin-top:0;color:var(--navy)}.stats strong{display:block;font-size:28px}.stats span,.tile p{color:var(--muted)}.tiles{grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;margin-bottom:16px}.form-grid,.tiles{display:grid;gap:12px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:12px;align-items:flex-end}.form-grid>*{min-width:0}.form-grid .wide,.form-grid h2,.form-hint{grid-column:1/-1}label{display:grid;grid-gap:6px;gap:6px;color:#344054;font-weight:650}.inline-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px}.tabs{display:flex;gap:8px;margin:12px 0;overflow:auto}.tabs a{border:1px solid var(--line);border-radius:999px;padding:8px 12px;background:#fff;white-space:nowrap}.tabs a.active{border-color:var(--brand);background:var(--brand);color:#fff}.table-wrap{overflow:auto;background:#eef2f6;border:1px solid var(--line);border-radius:8px;padding:8px}table{width:100%;min-width:760px;border-collapse:separate;border-spacing:0 8px}td,th{padding:10px;text-align:left;vertical-align:middle}th{background:#f8fafc;color:#475467;font-size:13px}tbody td,th{border-bottom:1px solid var(--line)}tbody td{background:#fff;border-top:1px solid var(--line)}tbody td:first-child{border-left:1px solid var(--line);border-radius:8px 0 0 8px}tbody td:last-child{border-right:1px solid var(--line);border-radius:0 8px 8px 0}tbody tr:nth-child(2n) td{background:#fbfcfe}tbody tr:hover td{background:#f2f8f7}.pending-row td{background:#fffbeb;border-left:4px solid #f59e0b}.rejected-row td{background:#fef3f2;border-left:4px solid #ef4444}.paid-row td{background:#ecfdf3}.manager-row td{background:#eff8ff}.actions{display:flex;flex-wrap:wrap;gap:6px}.date-cell small{display:block;color:var(--muted);font-size:11px}.date-cell strong{display:block;font-size:18px;line-height:1}.rate-grid{display:grid;grid-gap:8px;gap:8px}.rate-head{display:grid;grid-template-columns:82px 1fr 1fr;align-items:center;grid-gap:8px;gap:8px;color:#475467;font-size:13px;font-weight:700}.rate-grid label{grid-template-columns:82px 1fr 1fr;align-items:center}.rate-grid .single-rate{grid-template-columns:110px minmax(180px,320px)}.check-row{display:flex;align-items:center;gap:8px;font-weight:650}.check-row input{width:18px;min-height:18px}.company-row{grid-template-columns:1.1fr 1.4fr 1fr 140px 88px;grid-gap:8px;border:1px solid #cbd5e1;border-left:5px solid var(--brand);border-radius:8px}.company-row,.user-row{display:grid;gap:8px;align-items:center;padding:10px;background:#fff}.user-row{grid-template-columns:1fr 110px 130px 1.2fr 1fr 1fr 1fr 1fr 1fr 80px;grid-gap:8px;border:1px solid #cbd5e1;border-left:5px solid #64748b;border-radius:8px}.work-list{display:grid;grid-gap:10px;gap:10px}.work-calendar{display:grid;grid-gap:12px;gap:12px}.calendar-head{display:grid;grid-template-columns:88px 1fr 88px;grid-gap:8px;gap:8px;align-items:center}.calendar-head h2{margin:0;text-align:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-gap:4px;gap:4px}.calendar-weekday{padding:4px 0;color:var(--muted);font-size:12px;font-weight:700;text-align:center}.calendar-day{display:grid;align-content:start;grid-gap:4px;gap:4px;min-height:64px;padding:8px 5px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink)}.calendar-day.blank{border-color:transparent;background:transparent}.calendar-day.has-work{border-color:#fdba74;background:#fff7ed}.calendar-day.selected{outline:2px solid var(--brand);outline-offset:1px}.calendar-date{font-weight:800;line-height:1}.calendar-count{overflow:hidden;color:#c2410c;font-size:11px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.selected-date-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px;padding:12px;border:1px solid #99f6e4;border-radius:8px;background:#f0fdfa}.work-grid{display:grid;grid-template-columns:110px minmax(170px,1.7fr) 78px 78px minmax(150px,1.4fr) 90px;grid-gap:8px;gap:8px;align-items:center}input[type=file]{width:100%;padding:6px 0}input[type=file]::-webkit-file-upload-button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-weight:700;font-size:14px;margin-right:10px;cursor:pointer}input[type=file]::file-selector-button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-weight:700;font-size:14px;margin-right:10px;cursor:pointer}.dev-switch{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 14px;background:#fef3c7;border-bottom:1px solid #fcd34d;font-size:13px}.dev-switch-label{font-weight:700;color:#92400e}.dev-switch-btn{padding:6px 12px;border:1px solid #d97706;border-radius:999px;background:#fff;color:#92400e;font-weight:600}.dev-switch-btn.current{background:#d97706;color:#fff}.bulk-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bulk-check{width:22px;height:22px;min-height:22px;accent-color:var(--brand)}.select-all{display:inline-flex;align-items:center;gap:6px;font-weight:700;white-space:nowrap}.select-all input{width:22px;height:22px}.report-groups{display:grid;grid-gap:14px;gap:14px}.report-group h3{margin:0 0 8px;font-size:13px;color:#475467}.work-summary{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 12px}.work-summary .work-units{font-weight:700;color:var(--brand)}.work-edit{margin-top:6px;border-top:1px dashed #e4e7ec}.work-edit summary{cursor:pointer;color:#475467;font-size:13px;font-weight:600;padding:8px 0 4px;width:-moz-fit-content;width:fit-content}.work-edit[open] summary{color:var(--brand);margin-bottom:8px}.work-card{border:1px solid #cbd5e1;border-left:5px solid var(--brand);border-radius:8px;padding:12px;background:#fff;box-shadow:0 1px 3px rgba(16,24,40,.06)}.work-card .actions{justify-content:flex-end;margin-top:8px}.work-grid>*{min-width:0}.work-value{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.work-field{display:block;min-width:0}.work-field input,.work-field select{width:100%}.field-label{display:none}.work-reason{grid-column:1/-2}.date-edit{display:grid;grid-gap:4px;gap:4px;width:100%;min-width:0}.date-edit input{width:100%;min-width:0;padding:7px 6px;text-align:center}.date-edit div{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);grid-gap:3px;gap:3px;align-items:center;min-width:0}.date-edit span{min-width:0}.payment-card,.payment-list{display:grid;grid-gap:12px;gap:12px}.payment-card{padding:16px;background:#fff;border:1px solid var(--line);border-radius:8px}.payment-card.paid{border-color:#86efac;background:#f0fdf4}.payment-actions,.payment-main{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px}.payment-main h3{margin-bottom:4px}.payment-totals{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:8px;gap:8px;margin:0}.payment-totals div{border:1px solid var(--line);border-radius:8px;padding:10px;background:#fff}.payment-totals dt{color:var(--muted);font-size:12px;font-weight:700}.payment-totals dd{margin:4px 0 0;font-weight:800}.confirmation-text{margin:0;padding:12px;white-space:pre-wrap;font-family:inherit;border:1px solid var(--line);border-radius:8px;background:#f8fafc}.payment-confirm-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.payment-confirm-form .wide{grid-column:1/-1}@media (max-width:768px){.company-row,.user-row,.work-grid{grid-template-columns:1fr}.calendar-head{grid-template-columns:74px 1fr 74px}.calendar-head .button{padding:8px 6px;text-align:center}.calendar-grid{gap:3px}.calendar-day{min-height:54px;padding:6px 3px}.calendar-count{font-size:10px}.payment-confirm-form,.payment-totals{grid-template-columns:1fr}.work-field{display:grid;grid-gap:6px;gap:6px;min-width:0}.field-label{display:block;color:#475467;font-size:12px;font-weight:700}.topbar{align-items:center;flex-wrap:wrap}.menu-button{display:inline-grid;place-items:center;width:42px;height:42px;margin-left:auto;border:1px solid rgba(255,255,255,.55);border-radius:8px;background:transparent;font-size:22px;line-height:1;color:#fff}nav{display:none;order:5;flex-basis:100%;flex-direction:column;align-items:stretch;overflow:visible}.menu-toggle:checked~nav{display:flex}.container{padding:12px}.form-grid,.stats,.tiles{grid-template-columns:1fr}.role{order:3}table{min-width:680px}}