*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:#f8fafc;color:#111827;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}.screen{min-height:100dvh;padding:22px;display:flex;align-items:center;justify-content:center}.panel{width:min(100%,430px);border:1px solid #e5e7eb;border-radius:8px;background:#fff;box-shadow:0 18px 60px #0f172a1f;padding:22px}.app-panel{align-self:stretch;min-height:calc(100dvh - 44px);display:flex;flex-direction:column;gap:18px}.brand-row,.topbar,.status-card,.notice{display:flex;align-items:center;gap:12px}.brand-mark,.icon-button{width:48px;height:48px;border-radius:8px;display:grid;place-items:center;border:0}.brand-mark{background:#111827;color:#fff}.icon-button{background:#f1f5f9;color:#111827}.topbar{justify-content:space-between}h1,p{margin:0}h1{font-size:24px;line-height:1.15;letter-spacing:0}.brand-row p,.eyebrow,.status-card span,.notice span,.notice div span{color:#64748b;font-size:14px}.eyebrow{margin-bottom:4px;text-transform:uppercase;font-size:12px;font-weight:700}.stack{margin-top:22px;display:grid;gap:16px}.field{display:grid;gap:7px}.field span{font-size:13px;font-weight:700;color:#334155}.field input{width:100%;min-height:48px;border:1px solid #cbd5e1;border-radius:8px;padding:0 14px;outline:none;color:#111827}.field input:focus{border-color:#111827;box-shadow:0 0 0 3px #1118271f}.primary,.punch{border:0;border-radius:8px;font-weight:800;color:#fff}.primary{min-height:50px;background:#111827}.primary:disabled,.punch:disabled{opacity:.65}.status-card{border:1px solid #e2e8f0;background:#f8fafc;border-radius:8px;padding:14px}.status-card div{display:grid;gap:3px}.punch-grid{display:grid;gap:12px;grid-template-columns:1fr 1fr}.punch{min-height:132px;font-size:28px}.punch-in{background:#047857}.punch-out{background:#b45309}.notice{border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;padding:12px}.notice-ok{border-color:#a7f3d0;background:#ecfdf5;color:#065f46}.notice-warn{border-color:#fde68a;background:#fffbeb;color:#92400e}.notice div{display:grid;gap:2px}.error,.status-text{color:#b91c1c;font-size:14px}.status-text{color:#334155}@media(max-width:360px){.screen{padding:14px}.panel{padding:18px}.punch-grid{grid-template-columns:1fr}.punch{min-height:96px}}
