*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5;color:#1a1a2e;background:#f5f5f5;-webkit-font-smoothing:antialiased;min-height:100vh}button{cursor:pointer;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.auth-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.auth-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000014;padding:2.5rem 2rem;width:100%;max-width:380px}.auth-title{text-align:center;font-size:1.6rem;margin:0 0 1.5rem;color:#1a1a2e}.auth-tabs{display:flex;border-bottom:2px solid #eee;margin-bottom:1.5rem}.auth-tabs button{flex:1;background:none;border:none;padding:.6rem;font-size:.95rem;cursor:pointer;color:#888;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.auth-tabs button.active{color:#1a1a2e;border-bottom-color:#1a1a2e;font-weight:600}form{display:flex;flex-direction:column;gap:1rem}label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;color:#444;text-align:left}input{padding:.65rem .75rem;border:1.5px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s}input:focus{border-color:#1a1a2e}.auth-error{font-size:.85rem;color:#d32f2f;margin:0;text-align:center}.auth-submit{margin-top:.5rem;padding:.75rem;background:#1a1a2e;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-submit:hover:not(:disabled){opacity:.85}.auth-footer{text-align:center;font-size:.85rem;color:#666;margin-top:1rem}.auth-footer a{color:#1a1a2e;font-weight:600;text-decoration:underline}.onboard-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:1rem}.onboard-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000014;padding:2.5rem 2rem;width:100%;max-width:480px}.onboard-card h1{font-size:1.5rem;margin-bottom:.5rem;color:#1a1a2e}.onboard-sub{color:#666;margin-bottom:1.5rem}.role-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.role-option{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;padding:1rem 1.25rem;border:2px solid #e0e0e0;border-radius:10px;background:#fff;text-align:left;transition:border-color .2s,background .2s}.role-option .role-icon{font-size:1.5rem;margin-bottom:.25rem}.role-option strong{font-size:1rem;color:#1a1a2e}.role-option span{font-size:.85rem;color:#666}.role-option.selected{border-color:#1a1a2e;background:#f0f0f5}.onboard-error{color:#d32f2f;font-size:.85rem;margin-bottom:1rem;text-align:center}.onboard-btn{width:100%;padding:.75rem;background:#1a1a2e;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;transition:opacity .2s}.onboard-btn:disabled{opacity:.5;cursor:not-allowed}.onboard-btn:hover:not(:disabled){opacity:.85}.setup-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000014;padding:2.5rem 2rem;width:100%;max-width:520px}.setup-card h1{font-size:1.4rem;margin-bottom:.4rem;color:#1a1a2e}.field input,.field select,.field textarea{padding:.65rem .75rem;border:1.5px solid #ddd;border-radius:8px;font-size:.95rem;outline:none;transition:border-color .2s;background:#fff}.field input:focus,.field select:focus,.field textarea:focus{border-color:#1a1a2e}.field textarea{resize:vertical;min-height:80px}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.profile-select-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:1rem}.profile-select-card{background:#fff;border-radius:12px;box-shadow:0 4px 24px #00000014;padding:2.5rem 2rem;width:100%;max-width:400px}.profile-select-card h1{font-size:1.4rem;margin-bottom:.4rem}.sub{color:#666;font-size:.9rem;margin-bottom:1.5rem}.company-list{display:flex;flex-direction:column;gap:.75rem}.company-btn{background:#fff;border:2px solid #e0e0e0;border-radius:10px;padding:1rem 1.25rem;text-align:left;transition:border-color .2s}.company-btn:hover{border-color:#1a1a2e}.company-btn-name{font-weight:600;font-size:1rem;margin:0;color:#1a1a2e}.dashboard{max-width:800px}.page-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.page-header h2{font-size:1.4rem;margin:0}.live-badge{background:#e8f5e9;color:#2e7d32;font-size:.75rem;font-weight:600;padding:.2rem .6rem;border-radius:12px}.stat-row{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.stat-card{background:#fff;border-radius:10px;padding:1rem 1.5rem;box-shadow:0 2px 8px #0000000f;min-width:140px}.stat-num{font-size:2rem;font-weight:700;color:#1a1a2e;margin:0}.stat-label{font-size:.8rem;color:#888;margin:0}.clocked-list{display:flex;flex-direction:column;gap:.75rem}.clocked-row{background:#fff;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d}.site-name{font-size:.85rem;color:#666;margin:0}.time-badge{background:#f0f0f5;padding:.3rem .75rem;border-radius:8px;font-size:.85rem;font-weight:600;color:#1a1a2e;white-space:nowrap}.empty{color:#999;font-size:.95rem}.workers-page h2{font-size:1.4rem;margin-bottom:1.5rem}.workers-page h3{font-size:1rem;font-weight:600;color:#555;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.workers-page section{margin-bottom:2rem}.worker-list{display:flex;flex-direction:column;gap:.75rem}.worker-card{background:#fff;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d;gap:1rem;flex-wrap:wrap}.worker-card.pending{border-left:4px solid #f59e0b}.worker-name{font-weight:600;margin:0}.worker-meta{font-size:.82rem;color:#888;margin:0}.worker-actions{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.btn-approve{background:#1a1a2e;color:#fff;border:none;border-radius:6px;padding:.4rem .9rem;font-size:.85rem;font-weight:600}.btn-deny{background:none;color:#d32f2f;border:1.5px solid #d32f2f;border-radius:6px;padding:.4rem .9rem;font-size:.85rem}.btn-toggle{background:none;border:1.5px solid #ccc;border-radius:6px;padding:.4rem .9rem;font-size:.85rem;color:#444}.pay-rate-label{display:flex;align-items:center;gap:.3rem;font-size:.82rem;color:#666}.pay-rate-input{width:60px;padding:.3rem .4rem;border:1.5px solid #ddd;border-radius:6px;text-align:center}.sites-page h2{font-size:1.4rem;margin:0}.btn-primary{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:600;font-size:.9rem}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:none;border:1.5px solid #ccc;border-radius:6px;padding:.4rem .75rem;font-size:.85rem;color:#444}.btn-danger-ghost{background:none;border:1.5px solid #fca5a5;border-radius:6px;padding:.4rem .75rem;font-size:.85rem;color:#d32f2f}.sites-list{display:flex;flex-direction:column;gap:.75rem}.site-card{background:#fff;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d;gap:1rem;flex-wrap:wrap}.site-name{font-weight:600;margin:0}.site-address{font-size:.85rem;color:#666;margin:0}.site-coords{font-size:.75rem;color:#aaa;margin:0;font-family:monospace}.site-actions{display:flex;gap:.5rem;flex-shrink:0}.field input{padding:.6rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none}.field input:focus{border-color:#1a1a2e}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem}.modal{background:#fff;border-radius:12px;padding:1.75rem;width:100%;max-width:480px;box-shadow:0 8px 32px #00000026}.modal h3{margin:0 0 1.25rem;font-size:1.1rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.onboard-error{color:#d32f2f;font-size:.85rem;margin-bottom:.75rem}.payroll-page{max-width:800px}.payroll-page h2{font-size:1.4rem;margin-bottom:1.5rem}.btn-run{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.65rem 1.25rem;font-weight:600;font-size:.9rem}.table-wrap{overflow-x:auto}.payroll-table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 2px 8px #0000000d}.payroll-table th{background:#f5f5f5;padding:.75rem 1rem;text-align:left;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:#666}.payroll-table td{padding:.75rem 1rem;border-top:1px solid #f0f0f0;font-size:.9rem}.payroll-table tfoot td{border-top:2px solid #e0e0e0;background:#fafafa}.media-page{max-width:1000px}.media-page h2{font-size:1.4rem;margin:0}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.photo-thumb{border:none;padding:0;border-radius:8px;overflow:hidden;aspect-ratio:1;background:#e0e0e0;cursor:pointer;transition:transform .15s}.photo-thumb:hover{transform:scale(1.03)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.lightbox-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:600;padding:1rem}.lightbox{max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:.75rem}.lightbox img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.lightbox-meta{display:flex;align-items:center;gap:1rem;color:#fff;font-size:.9rem}.lightbox-meta button{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;padding:.35rem .9rem;font-size:.85rem}.docs-page{max-width:800px}.docs-page h2{font-size:1.4rem;margin:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header select{padding:.5rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none}.doc-download{font-size:1.1rem;color:#aaa;flex-shrink:0}.settings-page{max-width:600px}.settings-page h2{font-size:1.4rem;margin-bottom:1.5rem}.settings-page h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#666;margin-bottom:.75rem}.code-banner{background:#1a1a2e;color:#fff;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:2rem}.code-label{font-size:.8rem;opacity:.7;margin:0}.code-value{font-size:2rem;font-weight:800;letter-spacing:.2em;margin:.2rem 0;font-family:monospace}.code-hint{font-size:.8rem;opacity:.6;margin:0}.settings-form section{background:#fff;border-radius:10px;padding:1.25rem;margin-bottom:1.25rem;box-shadow:0 2px 8px #0000000d}.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.75rem}.field label{font-size:.83rem;font-weight:600;color:#444}.field input,.field select{padding:.6rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none;background:#fff}.field input:focus,.field select:focus{border-color:#1a1a2e}.btn-save{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.75rem 2rem;font-weight:600;font-size:1rem}.btn-save:disabled{opacity:.5;cursor:not-allowed}.error-msg{color:#d32f2f;font-size:.85rem;margin-bottom:.75rem}.success-msg{color:#2e7d32;font-size:.85rem;margin-bottom:.75rem}.clock-page{max-width:480px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem}.clock-status-card{background:#fff;border-radius:16px;padding:2rem;text-align:center;box-shadow:0 4px 16px #00000012}.status-dot{width:20px;height:20px;border-radius:50%;margin:0 auto .75rem}.status-dot.in{background:#22c55e;box-shadow:0 0 0 6px #22c55e33}.status-dot.out{background:#94a3b8}.status-text{font-size:1.2rem;font-weight:700;margin:0 0 .25rem}.clock-site{font-size:.95rem;color:#555;margin:0}.clock-since{font-size:.82rem;color:#888;margin:.25rem 0 0}.site-selector{display:flex;flex-direction:column;gap:.4rem}.site-selector label{font-size:.85rem;font-weight:600;color:#444}.site-selector select{padding:.65rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none;background:#fff}.site-selector select:focus{border-color:#1a1a2e}.notes-field{display:flex;flex-direction:column;gap:.4rem}.notes-field label{font-size:.85rem;font-weight:600;color:#444}.notes-field textarea{padding:.65rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none;resize:vertical}.notes-field textarea:focus{border-color:#1a1a2e}.clock-error{color:#d32f2f;font-size:.85rem;background:#fef2f2;border-radius:8px;padding:.75rem 1rem}.clock-btn{padding:1rem;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;letter-spacing:.03em;transition:opacity .2s}.clock-btn:disabled{opacity:.5;cursor:not-allowed}.clock-btn.clock-in{background:#1a1a2e;color:#fff}.clock-btn.clock-out{background:#d32f2f;color:#fff}.clock-btn:hover:not(:disabled){opacity:.85}.gps-note{font-size:.78rem;color:#aaa;text-align:center;margin:0}.timesheet-page{max-width:700px}.timesheet-page h2{font-size:1.4rem;margin:0}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.total-badge{background:#1a1a2e;color:#fff;padding:.3rem .8rem;border-radius:12px;font-size:.85rem;font-weight:600}.entry-row{background:#fff;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d;gap:1rem}.entry-row.open{border-left:4px solid #22c55e}.entry-time{font-size:.82rem;color:#888;margin:0}.entry-time.out{color:#aaa}.entry-notes{font-size:.82rem;color:#666;font-style:italic;margin:.25rem 0 0}.entry-hours{font-weight:600;font-size:.9rem;white-space:nowrap}.active-tag{background:#dcfce7;color:#15803d;border-radius:8px;padding:.2rem .6rem;font-size:.8rem;font-weight:700}.worker-media-page{max-width:600px}.worker-media-page h2{font-size:1.4rem;margin-bottom:1.5rem}.worker-media-page h3{font-size:.9rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#888;margin-bottom:.75rem}.upload-form{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;margin-bottom:1.5rem}.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.field label{font-size:.85rem;font-weight:600;color:#444}.field select,.field input[type=file]{padding:.6rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none;background:#fff}.field select:focus{border-color:#1a1a2e}.progress-bar-wrap{background:#f0f0f5;border-radius:8px;height:24px;position:relative;margin-bottom:.75rem;overflow:hidden}.progress-bar{background:#1a1a2e;height:100%;transition:width .3s}.progress-bar-wrap span{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:#fff}.upload-error{color:#d32f2f;font-size:.85rem;margin-bottom:.75rem}.upload-success{color:#2e7d32;font-size:.85rem;margin-bottom:.75rem}.btn-upload{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;font-size:.95rem}.btn-upload:disabled{opacity:.5;cursor:not-allowed}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.recent-thumb{border-radius:8px;overflow:hidden;aspect-ratio:1;display:block}.recent-thumb img{width:100%;height:100%;object-fit:cover}.worker-docs-page{max-width:700px}.worker-docs-page h2{font-size:1.4rem;margin-bottom:1.5rem}.doc-list{display:flex;flex-direction:column;gap:.5rem}.doc-row{display:flex;align-items:center;gap:.75rem;background:#fff;border-radius:10px;padding:.85rem 1.25rem;box-shadow:0 2px 8px #0000000d;transition:background .15s}.doc-row:hover{background:#f5f5f5}.doc-icon{font-size:1.5rem;flex-shrink:0}.doc-info{flex:1;min-width:0}.doc-name{font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-meta{font-size:.8rem;color:#888;margin:0}.doc-dl{font-size:1.1rem;color:#aaa;flex-shrink:0}.worker-payroll-page{max-width:700px}.worker-payroll-page h2{font-size:1.4rem;margin-bottom:1.5rem}.payroll-controls{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem;flex-wrap:wrap}.date-field{display:flex;flex-direction:column;gap:.3rem}.date-field label{font-size:.83rem;font-weight:600;color:#444}.date-field input{padding:.6rem .75rem;border:1.5px solid #ddd;border-radius:8px;outline:none}.date-field input:focus{border-color:#1a1a2e}.btn-run{background:#1a1a2e;color:#fff;border:none;border-radius:8px;padding:.65rem 1.25rem;font-weight:600}.btn-run:disabled{opacity:.5;cursor:not-allowed}.pay-summary{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}.pay-stat{background:#fff;border-radius:10px;padding:1rem 1.25rem;flex:1;min-width:120px;box-shadow:0 2px 8px #0000000d}.pay-stat.highlight{background:#1a1a2e;color:#fff}.pay-num{font-size:1.4rem;font-weight:700;margin:0}.pay-label{font-size:.78rem;margin:0;opacity:.7}.entry-list{display:flex;flex-direction:column;gap:.6rem}.entry-row{background:#fff;border-radius:10px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000000d}.entry-site{font-weight:600;margin:0}.entry-time{font-size:.8rem;color:#888;margin:0}.entry-notes{font-size:.8rem;color:#666;font-style:italic;margin:.2rem 0 0}.entry-right{text-align:right;flex-shrink:0}.entry-hours{font-weight:600;margin:0}.entry-pay{font-size:.85rem;color:#2e7d32;font-weight:600;margin:0}.empty{color:#999;font-size:.9rem}.navbar{position:fixed;top:0;left:0;right:0;height:56px;background:#1a1a2e;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:100;box-shadow:0 2px 8px #0003}.navbar-brand{font-weight:700;font-size:1.1rem;letter-spacing:.02em}.navbar-right{display:flex;align-items:center;gap:.75rem}.company-switcher select{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:.25rem .5rem;font-size:.85rem}.user-menu{position:relative}.user-menu-btn{width:36px;height:36px;border-radius:50%;background:#fff3;border:2px solid rgba(255,255,255,.4);color:#fff;font-weight:700;font-size:.95rem;display:flex;align-items:center;justify-content:center}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;color:#1a1a2e;border-radius:8px;box-shadow:0 4px 20px #00000026;min-width:180px;padding:.5rem 0;z-index:200}.user-menu-email{padding:.5rem 1rem;font-size:.8rem;color:#666;border-bottom:1px solid #eee;margin-bottom:.25rem}.user-menu-dropdown button{width:100%;text-align:left;padding:.5rem 1rem;background:none;border:none;font-size:.9rem;color:#d32f2f}.user-menu-dropdown button:hover{background:#fef2f2}.sidenav{display:none}@media(min-width:768px){.sidenav{display:block;position:fixed;top:56px;left:0;bottom:0;width:220px;background:#fff;border-right:1px solid #e8e8e8;overflow-y:auto;z-index:90}.sidenav ul{list-style:none;padding:1rem 0}.sidenav a{display:block;padding:.65rem 1.25rem;font-size:.9rem;color:#555;border-left:3px solid transparent;transition:color .15s,background .15s}.sidenav a:hover{background:#f5f5f5;color:#1a1a2e}.sidenav a.active{color:#1a1a2e;font-weight:600;border-left-color:#1a1a2e;background:#f0f0f5}}.bottomnav{position:fixed;bottom:0;left:0;right:0;height:64px;background:#fff;border-top:1px solid #e8e8e8;display:flex;z-index:100}.bottomnav a{flex:1;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#888;font-weight:500;transition:color .15s}.bottomnav a.active{color:#1a1a2e;font-weight:700}.bottomnav a:hover{color:#1a1a2e}@media(min-width:768px){.bottomnav{display:none}}.shell{display:flex;flex-direction:column;min-height:100vh}.shell-body{display:flex;flex:1;padding-top:56px}.shell-main{flex:1;padding:1.5rem;overflow-y:auto;padding-bottom:72px}@media(min-width:768px){.shell-body{margin-left:220px}.shell-main{padding-bottom:1.5rem}}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,sans-serif;background:#f5f5f5;color:#1a1a2e}.loading{min-height:100vh;display:flex;align-items:center;justify-content:center;color:#888}.app{max-width:900px;margin:0 auto;padding:2rem 1.5rem}header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e0e0e0;padding-bottom:1rem;margin-bottom:2rem}header h1{margin:0;font-size:1.4rem}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{font-size:.9rem;color:#555}.user-info button{background:none;border:1.5px solid #ccc;border-radius:6px;padding:.35rem .75rem;font-size:.85rem;cursor:pointer;color:#444;transition:border-color .2s,color .2s}.user-info button:hover{border-color:#1a1a2e;color:#1a1a2e}
