*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f172a;--surface: #1e293b;--surface2: #273044;--border: #334155;--text: #f1f5f9;--muted: #94a3b8;--accent: #f59e0b;--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--radius: 12px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:16px;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer;border:none}input{font-family:var(--font)}.loading-screen,.error-screen{display:flex;align-items:center;justify-content:center;height:100vh}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header,.admin-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.header-logo{font-weight:700;font-size:18px;color:var(--accent)}.header-name,.back-btn{color:var(--muted);font-size:14px}.admin-header nav{display:flex;gap:16px}.admin-header nav a{color:var(--muted);font-size:14px}.admin-header nav a:hover{color:var(--text)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{width:100%;max-width:380px;background:var(--surface);border-radius:var(--radius);padding:40px 32px;display:flex;flex-direction:column;gap:16px}.login-logo{font-size:28px;font-weight:800;color:var(--accent);letter-spacing:-1px}.login-card h1{font-size:22px}.login-card p{color:var(--muted);font-size:15px}.login-card input{width:100%;padding:14px 16px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:18px;outline:none;letter-spacing:2px}.login-card input:focus{border-color:var(--accent)}button{width:100%;padding:14px;background:var(--accent);color:#0f172a;font-size:16px;font-weight:700;border-radius:8px;transition:opacity .15s}button:disabled{opacity:.5;cursor:not-allowed}button:hover:not(:disabled){opacity:.9}button.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}button.small{width:auto;padding:6px 12px;font-size:13px}.error{color:var(--red);font-size:14px}.shift-list-screen main{padding:20px}.shift-list-screen h2{margin-bottom:16px}.shift-list{list-style:none;display:flex;flex-direction:column;gap:12px}.shift-card{display:block;background:var(--surface);border-radius:var(--radius);padding:16px 20px;border:1px solid var(--border);transition:border-color .15s}.shift-card:hover{border-color:var(--accent)}.shift-card-header{display:flex;justify-content:space-between;margin-bottom:6px}.shift-date{font-weight:600;font-size:15px}.shift-client{font-size:18px;font-weight:700;margin-bottom:4px}.shift-meta{color:var(--muted);font-size:14px;display:flex;gap:6px;margin-bottom:4px}.shift-address{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.badge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.5px}.badge-scheduled{background:#1e3a5f;color:#60a5fa}.badge-active{background:#14532d;color:var(--green)}.badge-completed{background:#1e293b;color:var(--muted)}.badge-cancelled{background:#450a0a;color:var(--red)}.shift-detail-screen main{padding:20px}.event-summary-card{background:var(--surface);border-radius:var(--radius);padding:20px;margin-bottom:20px;border:1px solid var(--border)}.event-summary-client{font-size:22px;font-weight:700;margin-bottom:4px}.event-summary-meta{color:var(--muted);font-size:14px;margin-bottom:4px}.event-summary-address{color:var(--muted);font-size:13px}.clock-result{padding:12px 16px;border-radius:8px;margin-bottom:16px}.clock-result.success{background:#14532d;color:var(--green)}.clock-result.flagged{background:#451a03;color:var(--yellow)}.geo-error{background:#450a0a;color:var(--red);padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.checkpoint-timeline{display:flex;flex-direction:column}.checkpoint-item{display:flex;gap:16px}.checkpoint-connector{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:36px}.checkpoint-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;border:2px solid var(--border);background:var(--bg);color:var(--muted)}.checkpoint-dot.done{background:var(--green);border-color:var(--green);color:#fff}.checkpoint-dot.next{border-color:var(--accent);color:var(--accent);background:var(--bg)}.checkpoint-line{width:2px;flex:1;min-height:24px;background:var(--border);margin:4px 0}.checkpoint-line.done{background:var(--green)}.checkpoint-content{flex:1;padding-bottom:24px}.checkpoint-name{font-weight:600;font-size:15px;margin-bottom:2px}.checkpoint-time{color:var(--muted);font-size:13px;margin-bottom:10px;display:flex;gap:10px}.checkpoint-location{color:var(--muted)}.checkpoint-item.future .checkpoint-name,.checkpoint-item.future .checkpoint-time{opacity:.5}.checkin-btn{background:var(--accent);color:#0f172a;font-size:16px;font-weight:700;padding:14px 24px;border-radius:10px;width:100%;max-width:300px}.btn-loading{opacity:.7}.admin-screen main{padding:20px}.stat-row{display:flex;gap:12px;margin-bottom:24px}.stat-card{flex:1;background:var(--surface);border-radius:var(--radius);padding:16px;text-align:center;border:1px solid var(--border)}.stat-card.stat-alert{border-color:var(--yellow)}.stat-value{font-size:28px;font-weight:800}.stat-label{color:var(--muted);font-size:13px;margin-top:2px}.event-list{list-style:none;display:flex;flex-direction:column;gap:8px}.event-card{display:block;background:var(--surface);border-radius:10px;padding:14px 16px;border:1px solid var(--border)}.event-card.active{border-color:var(--green)}.event-card-header{display:flex;justify-content:space-between;margin-bottom:4px}.event-card-meta{color:var(--muted);font-size:13px}.event-card-staff{color:var(--muted);font-size:13px;margin-top:2px}.event-date{color:var(--muted);font-size:13px}.filter-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.filter-row label{display:flex;align-items:center;gap:8px;font-size:14px}.timesheet-table{width:100%;border-collapse:collapse;font-size:14px}.timesheet-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase}.timesheet-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:top}.timesheet-table tr.row-flagged td{background:#1c1507}.text-warn{color:var(--yellow)}.action-group{display:flex;gap:8px;flex-wrap:wrap}.action-group input{flex:1;min-width:120px}.payroll-card{background:var(--surface);border-radius:var(--radius);padding:24px;max-width:600px}.payroll-card h3{margin-bottom:8px}.period-row{display:flex;gap:16px;margin:20px 0;flex-wrap:wrap}.period-row label{display:flex;flex-direction:column;gap:6px;font-size:14px;flex:1;min-width:140px}.period-row input{padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:15px}.export-btn{max-width:280px}.export-instructions{margin-top:24px}.export-instructions h4{margin-bottom:8px;color:var(--muted);font-size:14px}.export-instructions ol{padding-left:20px;color:var(--muted);font-size:14px;line-height:1.8}.muted{color:var(--muted)}.empty-state{color:var(--muted);padding:32px;text-align:center}section{margin-bottom:32px}section h3{margin-bottom:12px;font-size:16px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
