*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#1a1a2e;--surface:#16213e;--border:#0f3460;--accent-in:#4ade80;--accent-out:#f87171;--text:#e2e8f0;--text-muted:#94a3b8}body{background:var(--bg);color:var(--text);max-width:480px;margin:0 auto;padding:1rem;font-family:system-ui,sans-serif;line-height:1.5}h1{letter-spacing:.05em;margin-bottom:1.5rem;font-size:1.5rem}h2{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem;font-size:.75rem}section{margin-bottom:2rem}.warn{background:#7c2d12;border:1px solid #ea580c;border-radius:6px;margin-bottom:1.5rem;padding:.5rem .75rem;font-size:.85rem}.tracker{background:var(--surface);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem 1rem;display:flex}.tracker-in{border-left:4px solid var(--accent-in)}.tracker-out{border-left:4px solid var(--accent-out)}.tracker-info{flex-direction:column;gap:.15rem;display:flex}.tracker-name{font-size:1rem;font-weight:600}.tracker-status{letter-spacing:.1em;color:var(--text-muted);font-size:.7rem}.tracker-today{color:var(--text-muted);font-size:.8rem}.punch-btn{background:var(--border);color:var(--text);cursor:pointer;border:none;border-radius:6px;padding:.4rem .9rem;font-size:.9rem}.punch-btn:active{opacity:.7}@keyframes punch-in{0%{opacity:0;transform:scale(.85)}12%{opacity:1;transform:scale(1.04)}20%{transform:scale(1)}70%{opacity:1}to{opacity:0}}.punch-overlay{z-index:100;pointer-events:none;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.punch-flash{border:2px solid;border-radius:16px;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 3rem;animation:3s forwards punch-in;display:flex}.punch-flash-in{color:var(--accent-in);background:#4ade801a}.punch-flash-out{color:var(--accent-out);background:#f871711a}.punch-flash-action{letter-spacing:.1em;font-size:4rem;font-weight:800;line-height:1}.punch-flash-name{letter-spacing:.08em;opacity:.8;font-size:2.5rem}.empty{color:var(--text-muted);font-size:.9rem}.log{flex-direction:column;gap:.4rem;list-style:none;display:flex}.log-entry{border-bottom:1px solid var(--border);grid-template-columns:2.5rem 1fr auto;align-items:center;gap:.75rem;padding:.4rem 0;font-size:.85rem;display:grid}.log-action{letter-spacing:.05em;font-size:.7rem;font-weight:700}.log-action-in{color:var(--accent-in)}.log-action-out{color:var(--accent-out)}.log-name{color:var(--text)}.log-time{color:var(--text-muted);white-space:nowrap}
