:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;--bg:#fafaf9;--surface:#fff;--surface-2:#f5f5f4;--surface-3:#fff;--border:#e7e5e4;--border-strong:#d6d3d1;--text:#0c0a09;--text-2:#57534e;--text-3:#a8a29e;--accent:#2563eb;--accent-ink:#fff;--accent-soft:#dbeafe;--success:#16a34a;--success-soft:#dcfce7;--success-soft-border:#bbf7d0;--warn:#ea580c;--warn-soft:#ffedd5;--warn-soft-border:#fed7aa;--danger:#dc2626;--danger-soft:#fee2e2;--danger-soft-border:#fecaca;--slate:#1c1917;--row-flag-bg:#fff7ed;--radius:10px;--radius-sm:6px;--shadow-sm:0 1px 2px #0f0c080a;--shadow:0 4px 12px #0f0c080f;--mono:ui-monospace, "SF Mono", Menlo, Consolas, monospace;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Inter, system-ui, sans-serif}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--bg:#0c0a09;--surface:#1c1917;--surface-2:#292524;--surface-3:#242022;--border:#292524;--border-strong:#3a3633;--text:#fafaf9;--text-2:#a8a29e;--text-3:#78716c;--accent:#60a5fa;--accent-ink:#0c0a09;--accent-soft:#1e3a8a;--success:#22c55e;--success-soft:#14532d;--success-soft-border:#166534;--warn:#fb923c;--warn-soft:#431407;--warn-soft-border:#9a3412;--danger:#f87171;--danger-soft:#450a0a;--danger-soft-border:#7f1d1d;--slate:#0c0a09;--row-flag-bg:#2a1a06;--shadow-sm:0 1px 2px #0006;--shadow:0 4px 14px #0006}}*{box-sizing:border-box}html,body,#root{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;min-height:100%;margin:0;padding:0;font-size:14px;line-height:1.45}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{letter-spacing:-.01em;margin:0;font-weight:600}button{font-family:inherit}code,.mono{font-family:var(--mono);font-size:.92em}.admin-shell{grid-template-columns:220px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--slate);color:#e7e5e4;flex-direction:column;gap:18px;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0}.sidebar .brand{letter-spacing:-.01em;align-items:center;gap:10px;padding:4px 8px;font-size:15px;font-weight:600;display:flex}.sidebar .brand .dot{background:linear-gradient(135deg,#fbbf24,#f97316);border-radius:6px;width:22px;height:22px;display:inline-block}.sidebar nav{flex-direction:column;gap:1px;display:flex}.sidebar nav a{color:#d6d3d1;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:13.5px;display:flex}.sidebar nav a:hover{color:#fff;background:#292524;text-decoration:none}.sidebar nav a.active{color:#fff;background:#292524}.sidebar nav .label{color:#78716c;text-transform:uppercase;letter-spacing:.06em;padding:14px 10px 4px;font-size:11px}.sidebar .user{border-top:1px solid #292524;flex-direction:column;gap:4px;margin-top:auto;padding:10px;display:flex}.sidebar .user .name{color:#fafaf9;font-size:13px}.sidebar .user .meta{color:#a8a29e;font-size:11.5px}.sidebar .user button{color:#a8a29e;text-align:left;cursor:pointer;background:0 0;border:none;padding:0;font-size:11.5px}.sidebar .user button:hover{color:#fff;text-decoration:underline}.content{min-width:0;padding:28px 36px 80px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:22px;display:flex}.page-header h1{font-size:22px}.page-header .actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.btn{border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);height:34px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{background:var(--surface-2)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}.btn.primary:hover{filter:brightness(.95)}.btn.danger{background:var(--surface);border-color:var(--danger);color:var(--danger)}.btn.ghost{color:var(--text-2);background:0 0;border-color:#0000}.btn.ghost:hover{background:var(--surface-2);color:var(--text)}.btn.sm{height:28px;padding:0 10px;font-size:12px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px}.card+.card{margin-top:16px}.card h2{margin-bottom:12px;font-size:15px}.stat-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:22px;display:grid}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.stat .k{color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-size:11.5px}.stat .v{letter-spacing:-.02em;margin-top:6px;font-size:22px;font-weight:600}.stat .delta{color:var(--text-2);margin-top:4px;font-size:12px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto}.table-wrap.flush{background:0 0;border:0}table{border-collapse:collapse;width:100%;min-width:520px;font-size:13px}thead th{text-align:left;color:var(--text-2);background:var(--surface-2);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;padding:10px 14px;font-size:12px;font-weight:500}tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px}tbody tr:last-child td{border-bottom:0}tbody tr:hover{background:var(--surface-2)}.cell-mono{font-family:var(--mono);font-size:12.5px}.cell-name{flex-direction:column;display:flex}.cell-name .email{color:var(--text-2);font-size:12px}.badge{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);border-radius:999px;align-items:center;gap:5px;padding:2px 8px;font-size:11.5px;font-weight:500;display:inline-flex}.badge.arrive{background:var(--success-soft);color:var(--success);border-color:var(--success-soft-border)}.badge.depart{background:var(--surface-2);color:var(--text);border-color:var(--border)}.badge.start_break{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-soft-border)}.badge.end_break{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}.badge.live{background:var(--success-soft);color:var(--success);border-color:var(--success-soft-border)}.badge.live .pulse{background:var(--success);border-radius:999px;width:6px;height:6px;animation:1.6s ease-out infinite pulse;display:inline-block}@keyframes pulse{0%{box-shadow:0 0}to{box-shadow:0 0 0 8px #0000}}.badge.alert{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-soft-border)}.badge.warn{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-soft-border)}.badge.muted{background:var(--surface-2);color:var(--text-2)}.field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.field label{color:var(--text-2);font-size:12px;font-weight:500}.field input,.field select,.field textarea{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);height:36px;color:var(--text);padding:0 12px;font-family:inherit;font-size:13.5px}.field textarea{resize:vertical;height:auto;min-height:80px;padding:10px 12px}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.field-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.filter-bar{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:14px;display:flex}.filter-bar input,.filter-bar select{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);height:32px;color:var(--text);min-width:0;padding:0 10px;font-family:inherit;font-size:13px}.filter-bar .spacer{flex:1}.banner{border-radius:var(--radius);background:var(--warn-soft);border:1px solid var(--warn-soft-border);color:var(--warn);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;padding:12px 14px;font-size:13px;display:flex}.banner.danger{background:var(--danger-soft);border-color:var(--danger-soft-border);color:var(--danger)}.banner.success{background:var(--success-soft);border-color:var(--success-soft-border);color:var(--success)}.banner .grow{flex:1}.contractor-page{background:var(--bg);min-height:100dvh;color:var(--text);justify-content:center;display:flex}.phone{background:var(--bg);flex-direction:column;width:100%;max-width:480px;min-height:100dvh;display:flex}.phone .top{border-bottom:1px solid var(--surface);padding:22px 22px 14px}.phone .top .greeting{color:var(--text-2);font-size:13px}.phone .top .who{justify-content:space-between;align-items:baseline;gap:10px;margin-top:4px;display:flex}.phone .top .who .name{letter-spacing:-.01em;font-size:19px;font-weight:600}.phone .top .who .email{color:var(--text-3);font-size:12px;font-family:var(--mono);word-break:break-all}.phone .top .not-you{color:var(--text-2);margin-top:4px;font-size:12px}.phone .top .not-you button{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0}.phone .top .not-you button:hover{text-decoration:underline}.phone .status{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);margin:18px 22px;padding:14px 16px}.phone .status .row{color:var(--text-2);justify-content:space-between;font-size:13px;display:flex}.phone .status .row+.row{margin-top:6px}.phone .status .v{font-family:var(--mono);color:var(--text)}.phone .status.on .label{color:var(--success);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:8px;font-size:12px;display:flex}.phone .status.on .label .pulse{background:var(--success);border-radius:999px;width:7px;height:7px;animation:1.6s ease-out infinite pulse;display:inline-block}.phone .buttons{grid-template-columns:1fr 1fr;gap:12px;padding:4px 22px 22px;display:grid}.punch{letter-spacing:-.01em;cursor:pointer;text-align:left;color:#fff;border:1px solid #0000;border-radius:14px;flex-direction:column;justify-content:space-between;align-items:flex-start;min-height:110px;padding:18px;font-family:inherit;font-size:16px;font-weight:600;transition:transform 80ms;display:flex}.punch:active{transform:scale(.97)}.punch .glyph{background:#fff3;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.punch .name{font-size:17px}.punch.arrive{background:#16a34a}.punch.break{background:#f97316}.punch.endbreak{background:#2563eb}.punch.depart{background:#44403c;border-color:#57534e}.punch[disabled]{opacity:.4;cursor:not-allowed}.phone .note-row{padding:0 22px 16px}.phone .note-row label{color:var(--text-2);margin-bottom:6px;font-size:12px;display:block}.phone .note-row input{background:var(--surface);width:100%;color:var(--text);border:1px solid var(--border);border-radius:8px;height:38px;padding:0 12px;font-family:inherit;font-size:14px}.phone .footer-link{text-align:center;padding:18px 22px 30px;font-size:13px}.phone .footer-link a,.phone .footer-link button{color:var(--accent);cursor:pointer;font:inherit;background:0 0;border:none}.toast{color:#fff;z-index:200;text-align:center;background:#16a34a;border-radius:999px;max-width:calc(100vw - 32px);padding:10px 18px;font-size:13.5px;font-weight:500;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #0000004d}.toast.error{background:#dc2626}.signin-page{background:var(--bg);min-height:100dvh;color:var(--text);justify-content:center;display:flex}.signin{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;padding:22px;display:flex}.signin .brand{align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.signin .brand .dot{background:linear-gradient(135deg,#fbbf24,#f97316);border-radius:6px;width:22px;height:22px;display:inline-block}.signin h1{letter-spacing:-.02em;margin-top:28px;font-size:26px;font-weight:600}.signin form{flex-direction:column;gap:14px;margin-top:26px;display:flex}.signin .f{flex-direction:column;gap:6px;display:flex;position:relative}.signin .f label{color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:500}.signin .f input{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;height:50px;padding:0 14px;font-family:inherit;font-size:16px}.signin .f input:focus{border-color:#2563eb;outline:2px solid #2563eb}.signin .suggestions{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-top:6px;overflow:hidden}.signin .suggestion{border-bottom:1px solid var(--border);cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;background:0 0;border-top:none;border-left:none;border-right:none;flex-direction:column;gap:2px;padding:12px 14px;display:flex}.signin .suggestion:last-child{border-bottom:0}.signin .suggestion:hover,.signin .suggestion.active{background:var(--surface-2)}.signin .suggestion .n{color:var(--text);font-size:14.5px;font-weight:500}.signin .suggestion .e{font-family:var(--mono);color:var(--text-2);font-size:12.5px}.signin .cta{color:#fff;letter-spacing:-.01em;cursor:pointer;background:#16a34a;border:0;border-radius:12px;height:56px;margin-top:8px;font-family:inherit;font-size:17px;font-weight:600}.signin .cta:disabled{background:var(--surface-2);color:var(--text-3);cursor:not-allowed}.h-page{max-width:520px;margin:0 auto;padding:28px 22px 60px}.h-page .back{color:var(--text-2);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.h-page h1{letter-spacing:-.02em;margin-top:10px;font-size:22px}.day{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:14px;overflow:hidden}.day .day-head{background:var(--surface-2);border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;padding:12px 16px;display:flex}.day .day-head .date{font-size:14px;font-weight:600}.day .day-head .total{font-family:var(--mono);font-size:13px}.event-row{border-bottom:1px solid var(--border);grid-template-columns:84px minmax(0,1fr) auto;align-items:center;gap:12px;padding:10px 16px;display:grid}.event-row:last-child{border-bottom:0}.event-row .t{font-family:var(--mono);font-size:13px}.event-row .note{color:var(--text-2);word-break:break-word;margin-top:2px;font-size:12.5px}.event-row .edit{color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:12.5px}.event-row .edit:hover{text-decoration:underline}.login-wrap{background:var(--bg);place-items:center;min-height:100dvh;padding:24px;display:grid}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow);padding:28px}.login-card .brand{align-items:center;gap:10px;margin-bottom:22px;font-size:17px;font-weight:600;display:flex}.login-card .brand .dot{background:linear-gradient(135deg,#fbbf24,#f97316);border-radius:7px;width:26px;height:26px;display:inline-block}.login-card .error{color:var(--danger);text-align:center;margin-top:14px;font-size:13px}.qr-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:auto minmax(0,1fr);align-items:center;gap:28px;padding:28px;display:grid}.qr-wrap .qr{border-radius:var(--radius);border:1px solid var(--border);background:#fff;justify-content:center;align-items:center;padding:16px;display:flex}.qr-wrap h2{margin-bottom:6px;font-size:18px}.qr-wrap .url{font-family:var(--mono);color:var(--accent);word-break:break-all;font-size:13px}.edit-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.edit-row input,.edit-row select{border:1px solid var(--border-strong);height:28px;font-family:var(--mono);background:var(--surface);color:var(--text);border-radius:4px;padding:0 8px;font-size:12.5px}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.empty{text-align:center;color:var(--text-2);padding:36px 18px;font-size:13px}.loading{text-align:center;color:var(--text-3);padding:36px 18px;font-size:13px}@media (max-width:960px){.content{padding:22px 22px 80px}}@media (max-width:720px){.admin-shell{grid-template-columns:1fr}.sidebar{flex-flow:wrap;gap:8px;height:auto;padding:12px 14px;position:static;overflow-x:auto}.sidebar .user,.sidebar nav .label{display:none}.sidebar nav{flex-flow:wrap}.sidebar nav a{padding:6px 10px;font-size:12.5px}.content{padding:18px}.page-header h1{font-size:20px}}@media (max-width:480px){.stat .v{font-size:18px}.qr-wrap{text-align:center;grid-template-columns:1fr}}
