*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;background:#f5f6f8;color:#1f2329;-webkit-tap-highlight-color:transparent}.page{max-width:640px;margin:0 auto;padding:0 12px 96px}.center{min-height:60vh;display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center}.muted{color:#8f959e}.small{font-size:12px}.error{color:#d83931}.header{position:sticky;top:0;background:#f5f6f8;display:flex;align-items:center;justify-content:space-between;padding:14px 4px 10px;z-index:5}.title{font-size:18px;font-weight:600}.summary-bar{display:flex;flex-wrap:wrap;gap:6px;padding:2px 2px 8px}.chip.summary{flex:none;min-width:0;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:500;background:#fff;color:#646a73;cursor:default}.chip.summary.出勤{color:#2e7d32;border-color:#b7e0b9}.chip.summary.休息{color:#646a73}.chip.summary.请假{color:#f0a020;border-color:#f3d39b}.chip.summary.旷工{color:#d83931;border-color:#f3b6b3}.banner{padding:8px 12px;border-radius:8px;margin:6px 0;font-size:14px}.banner.error{background:#fdecec;color:#d83931}.banner.ok{background:#e8f5e9;color:#2e7d32}.group{background:#fff;border-radius:12px;padding:8px 12px;margin:10px 0}.group-title{font-size:14px;color:#646a73;margin:6px 2px 10px}.row{padding:10px 0;border-top:1px solid #f0f1f2}.row:first-of-type{border-top:none}.row-name{font-size:15px;font-weight:500;margin-bottom:8px}.status-group{display:flex;gap:8px;flex-wrap:wrap}.chip{flex:1;min-width:56px;padding:8px 0;border:1px solid #dee0e3;border-radius:8px;background:#fff;font-size:14px;color:#1f2329;cursor:pointer}.chip.active{color:#fff;border-color:transparent;font-weight:600}.chip.active.出勤{background:#2e7d32}.chip.active.休息{background:#8f959e}.chip.active.请假{background:#f0a020}.chip.active.旷工{background:#d83931}.note{width:100%;margin-top:8px;padding:7px 10px;border:1px solid #dee0e3;border-radius:8px;font-size:13px}.footer{position:fixed;left:0;right:0;bottom:0;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #eee}.btn{padding:8px 16px;border-radius:8px;border:1px solid #dee0e3;background:#fff;font-size:15px;cursor:pointer}.btn.ghost{color:#3370ff;border-color:#3370ff}.btn.primary{width:100%;background:#3370ff;color:#fff;border:none;padding:12px;font-weight:600}.btn.primary:disabled{opacity:.6}
